Part Number Hot Search : 
IRFIZ34E R5F21388 060PT BFR93 MRF275 A1705 09K31 DM9334N
Product Description
Full Text Search
 

To Download ZL50416 Datasheet File

  If you can't view the Datasheet, Please click here to try to view without PDF Reader .  
 
 


  Datasheet File OCR Text:
 ZL50416 Managed 16-Port 10/100M Layer-2 Ethernet Switch
Data Sheet
Features
* Integrated Single-Chip 10/100M Ethernet Switch
* Sixteen 10/100 Mbps auto-negotiating Fast Ethernet (FE) ports with RMII or GPSI (7WS) interface options per port
April 2006
Ordering Information ZL50416/GKC ZL50416GKG2 553 Pin HSBGA 553 Pin HSBGA**
*
Supports one Frame Data Buffer (FDB) memory domains (1 MB or 2 MB) with pipelined, sync-burst SRAM at 100 MHz
* Applies centralized shared memory architecture
**Pb Free Tin/Silver/Copper -40C to 85C * Packet Filtering and Port Security
* Static address filtering for source and/or destination MAC * Static MAC address not subject to aging * Secure mode freezes MAC address learning, each port may independently use this mode
*
L2 Switching
* MAC address self learning, up to 64K MAC addresses * Supports port-based and tagged-based VLAN (IEEE 802.1Q) * Supports up to 255 VLANs and IP multicast groups * VLAN tag insertion and stripping selectable on a per port, per VLAN basis * Supports spanning tree on per-system (IEEE 802.1D/w) or per-VLAN basis (IEEE 802.1s)
* *
* * *
Supports IP Multicast with IGMP snooping High performance packet classification and switching at full-wire speed CPU access supports the following interface options:
* 8/16-bit ISA interface in managed mode * Serial interface in unmanaged mode, with optional I2C EEPROM support
*
Supports Ethernet multicasting and broadcasting and flooding control Supports per-system option to enable flow control for best effort frames even on QoSenabled ports QoS Support
* 4 transmission priorities for Fast Ethernet ports * Per-queue weighted random early discard (WRED) with 2 drop precedence levels * Scheduling using delay bounded (DB), strict priority (SP), and Weighted Fair Queuing (WFQ) disciplines * User controlled WRED thresholds
VLAN 1 MCT
Frame Data Buffer A SRAM (1 M / 2 M)
FDB Interface LED
FCB
Frame Engine
Search Engine
MCT Link
16 x 10/100M RMII Ports 0 - 15
Management Module
16-bit Parallel / Serial
Figure 1 - System Block Diagram 1
Zarlink Semiconductor Inc. Zarlink, ZL and the Zarlink Semiconductor logo are trademarks of Zarlink Semiconductor Inc. Copyright 2003-2006, Zarlink Semiconductor Inc. All Rights Reserved.
ZL50416
* Buffer management: per-class, shared, and per-port buffer reservations
Data Sheet
*
Classification based on:
* * * * Port-based priority: priority in a frame can be overwritten by the priority of port VLAN Priority field in VLAN tagged frame (IEEE 802.1p) DS/TOS field in IP packet UDP/TCP logical ports: 8 hard-wired and 8 programmable ports, including one programmable range
* *
The drop precedence of the above classifications is programmable Supports IEEE 802.3ad link aggregation * 2 port trunking groups
* two groups for 10/100 ports, with up to 4 ports per group * Load sharing among trunked ports can be based on:
*
- Source and/or destination MAC address Port Mirroring
* supports 2 mirroring ports in managed mode * supports a dedicated mirroring port in unmanaged mode
* * * * * * *
Built-in MIB statistics counters Full Duplex Ethernet IEEE 802.3x Flow Control Backpressure flow control for Half Duplex ports Full set of LED signals provided by a serial interface Recognizes Simple Bandwidth Management (SBM) and Resource Reservation Protocol (RSVP) packets and forwards to CPU Built-in reset logic triggered by system malfunction Built-in self test (BIST) for internal and external SRAM
2
Zarlink Semiconductor Inc.
ZL50416 Description
Data Sheet
The ZL50416 is a high density, low cost, high performance, non-blocking Ethernet switch chip. A single chip provides 16 ports at 10/100 Mbps and a CPU interface for managed and unmanaged switch applications. The chip supports up to 64K MAC addresses and up to 255 tagged-based Virtual LANs (VLANs). The centralized shared memory architecture permits a very high performance packet forwarding rate at full wire speed. The chip is optimized to provide low-cost, high-performance workgroup switching. A Frame Buffer Memory domain utilizes cost-effective, high-performance synchronous SRAM with aggregate bandwidth of 6.4 Gbps to support full wire speed on all ports simultaneously. With delay bounded, strict priority, and/or WFQ transmission scheduling and WRED dropping schemes, the ZL50416 provides powerful QoS functions for various multimedia and mission-critical applications. The chip provides 4 transmission priorities and 2 levels of dropping precedence. Each packet is assigned a transmission priority and dropping precedence based on the VLAN priority field in a VLAN tagged frame, or the DS/TOS field, or the UDP/TCP logical port fields in IP packets. The ZL50416 recognizes a total of 16 UDP/TCP logical ports, 8 hardwired and 8 programmable (including one programmable range). The ZL50416 supports 2 groups of port trunking/load sharing. Two groups are dedicated to 10/100 ports, where each 10/100 group can contain up to 4 ports. Port trunking/load sharing can be used to group ports between interlinked switches to increase the effective network bandwidth. In half-duplex mode all ports support backpressure flow control to minimize the risk of losing data during long activity bursts. In full-duplex mode, IEEE 802.3x flow control is provided. The ZL50416 also supports a per-system option to enable flow control for best effort frames, even on QoS-enabled ports. Statistical information for SNMP and the Remote Monitoring Management Information Base (RMON MIB) are collected independently for all ports. Access to these statistical counters/registers is provided via the CPU interface. SNMP Management frames can be received and transmitted via the CPU interface creating a complete network management solution. The ZL50416 is fabricated using 0.25 micron technology. Inputs, however, are 3.3 V tolerant, and the outputs are capable of directly interfacing to LVTTL levels. The ZL50416 is packaged in a 553-pin Ball Grid Array package.
3
Zarlink Semiconductor Inc.
ZL50416 Changes Summary
The April 2006 issue is the starting point for the change summary section. Revision Date April 2006 Summary of Changes
Data Sheet
- Corrected ZL5041x ordering codes (should be /GKC) - Added Pb-free order code (ZL50416GKG2) - Corrected TSTOUT6 boostrap description, and clarified only applicable in "managed" mode - Corrected ECR1Pn default value (should be 0xC0) - Corrected PR100 default value (should be 0x35) - Corrected SFCB default value (should be 0x46) - Corrected CPU addresses for registers CPUQOSC1,2,3
4
Zarlink Semiconductor Inc.
ZL50416
Data Sheet
Table of Contents
1.0 BGA and Ball Signal Descriptions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12 1.1 BGA Views (Top-View) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12 1.1.1 Encapsulated view in managed mode . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12 1.1.2 Encapsulated view in unmanaged mode . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13 1.2 Ball - Signal Descriptions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14 1.3 Ball - Signal Name . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 23 1.4 Signal Mapping and Internal Pull Up/Down Configuration. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29 2.0 Block Functionality . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31 2.1 Frame Data Buffer (FDB) Interfaces . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31 2.2 MAC Modules . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31 2.2.1 RMII MAC Module (RMAC) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31 2.2.1.1 GPSI Interface . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31 2.2.1.2 SCANLINK and SCANCOL interface . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 33 2.2.2 CPU MAC Module (CMAC) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 33 2.2.3 PHY Addresses . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 33 2.3 Management Module . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 33 2.4 Frame Engine . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 34 2.5 Search Engine . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 34 2.6 LED Interface. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 34 2.6.1 Port Status . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 34 2.6.2 LED Interface Timing Diagram. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35 2.7 Internal Memory . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35 2.8 Timeout Reset Monitor . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35 3.0 System Configuration (Stand-alone and Stacking) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36 3.1 Management and Configuration . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36 3.2 Managed Mode . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36 3.2.1 Register Configuration, Frame Transmission, and Frame Reception . . . . . . . . . . . . . . . . . . . . . . . 36 3.2.1.1 Register Configuration . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36 3.2.1.2 Rx/Tx of Standard Ethernet Frames. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37 3.2.1.3 Control Frames. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37 3.3 Unmanaged Mode . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38 3.3.1 I2C Interface. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38 3.3.1.1 Start Condition . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38 3.3.1.2 Address . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38 3.3.1.3 Data Direction. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38 3.3.1.4 Acknowledgment . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39 3.3.1.5 Data . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39 3.3.1.6 Stop Condition . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39 3.3.2 Synchronous Serial Interface . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39 3.3.2.1 Write Command . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 40 3.3.2.2 Read Command . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 40 4.0 Data Forwarding Protocol . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 40 4.1 Unicast Data Frame Forwarding . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 40 4.2 Multicast Data Frame Forwarding . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41 4.3 Frame Forwarding To and From CPU . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41 5.0 Memory Interface . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 42 5.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 42 5.2 Memory Requirements . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 42 5.3 Memory Configurations . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43 6.0 Search Engine . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45 6.1 Search Engine Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45
5
Zarlink Semiconductor Inc.
ZL50416
Data Sheet
Table of Contents
6.2 Basic Flow . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45 6.3 Search, Learning, and Aging . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 46 6.3.1 MAC Search. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 46 6.3.2 Learning . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 46 6.3.3 Aging . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 46 6.4 MAC Address Filtering. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47 6.5 Port- and Tagged-Based VLAN. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47 6.5.1 Port-Based VLAN. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47 6.5.2 Tagged-Based VLAN . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 48 6.6 Quality of Service . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 48 6.6.1 Priority Classification Rule . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 49 7.0 Frame Engine . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 49 7.1 Data Forwarding Summary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 49 7.2 Frame Engine Details . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50 7.2.1 FCB Manager. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50 7.2.2 Rx Interface . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50 7.2.3 RxDMA. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50 7.2.4 TxQ Manager . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50 7.2.5 Port Control . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50 7.2.6 TxDMA . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50 8.0 Quality of Service and Flow Control . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50 8.1 Model. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50 8.2 Four QoS Configurations. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 52 8.3 Delay Bound . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 52 8.4 Strict Priority and Best Effort . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 52 8.5 Weighted Fair Queuing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53 8.6 Rate Control . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53 8.7 WRED Drop Threshold Management Support . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 54 8.8 Buffer Management . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 54 8.8.1 Dropping When Buffers Are Scarce . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 56 8.9 Flow Control Basics. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 56 8.9.1 Unicast Flow Control . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 56 8.9.2 Multicast Flow Control . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 57 8.10 Mapping to IETF DiffServ Classes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 57 9.0 Port Trunking . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 58 9.1 Features and Restrictions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 58 9.2 Unicast Packet Forwarding . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 58 9.3 Multicast Packet Forwarding . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 58 9.4 Unmanaged Trunking . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 59 10.0 Port Mirroring . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 59 10.1 Port Mirroring Features . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 59 10.2 Setting Registers for Port Mirroring . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 59 11.0 Hardware Statistics Counter . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 60 11.1 Hardware Statistics Counters List . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 60 11.2 IEEE 802.3 HUB Management (RFC 1516) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 61 11.2.1 Event Counters . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 61 11.2.1.1 Readablectet . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 61 11.2.1.2 ReadableFrame . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62 11.2.1.3 FCSErrors. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62 11.2.1.4 AlignmentErrors . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62 11.2.1.5 FrameTooLongs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62
6
Zarlink Semiconductor Inc.
ZL50416
Data Sheet
Table of Contents
11.2.1.6 ShortEvents . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62 11.2.1.7 Runts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 63 11.2.1.8 Collisions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 63 11.2.1.9 LateEvents . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 63 11.2.1.10 VeryLongEvents . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 63 11.2.1.11 DataRateMisatches . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 63 11.2.1.12 AutoPartitions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 63 11.2.1.13 TotalErrors. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 63 11.3 IEEE 802.1 Bridge Management (RFC 1286) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64 11.3.1 Event Counters . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64 11.3.1.1 InFrames . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64 11.3.1.2 OutFrames . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64 11.3.1.3 InDiscards. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64 11.3.1.4 DelayExceededDiscards . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64 11.3.1.5 MtuExceededDiscards . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64 11.4 RMON - Ethernet Statistic Group (RFC 1757) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64 11.4.1 Event Counters . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64 11.4.1.1 Drop Events . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64 11.4.1.2 Octets . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64 11.4.1.3 BroadcastPkts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64 11.4.1.4 MulticastPkts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64 11.4.1.5 CRCAlignErrors . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65 11.4.1.6 UndersizePkts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65 11.4.1.7 OversizePkts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65 11.4.1.8 Fragments . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65 11.4.1.9 Jabbers. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65 11.4.1.10 Collisions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 66 11.4.1.11 Packet Count for Different Size Groups . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 66 11.5 Miscellaneous Counters . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 66 12.0 Register Definition . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 67 12.1 Register Description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 67 12.2 Directly Accessed Registers (8/16-bit Access Only) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 72 12.3 Indirectly Accessed Registers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 76 12.3.1 (Group 0 Address) MAC Ports Group . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 76 12.3.1.1 ECR1Pn: Port n Control Register 1 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 76 12.3.1.2 ECR2Pn: Port n Control Register 2 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 76 12.3.2 (Group 1 Address) VLAN Group . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 78 12.3.2.1 AVTCL - VLAN Type Code Register Low . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 78 12.3.2.2 AVTCH - VLAN Type Code Register High. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 78 12.3.2.3 PVMAP00_0 - Port 00 Configuration Register 0 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 78 12.3.2.4 PVMAP00_1 - Port 00 Configuration Register 1 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 79 12.3.2.5 PVMAP00_2 - Port 00 Configuration Register 2 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 79 12.3.2.6 PVMAP00_3 - Port 00 Configuration Register 3 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 79 12.3.2.7 PVMAPnn_0,1,2,3 - Port nn Configuration Registers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 81 12.3.2.8 PVMODE . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 82 12.3.2.9 PVROUTE0 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 82 12.3.2.10 PVROUTE1 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 83 12.3.2.11 PVROUTE2 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 83 12.3.2.12 PVROUTE3 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 84 12.3.2.13 PVROUTE4 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 84 12.3.2.14 PVROUTE5 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 84 12.3.2.15 PVROUTE6 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 85
7
Zarlink Semiconductor Inc.
ZL50416
Data Sheet
Table of Contents
12.3.2.16 PVROUTE7 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 85 12.3.3 (Group 2 Address) Port Trunking Groups . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 86 12.3.3.1 TRUNK0_L - Trunk group 0 Low (Managed mode only) . . . . . . . . . . . . . . . . . . . . . . . . . . . 86 12.3.3.2 TRUNK0_M - Trunk group 0 Medium (Managed mode only) . . . . . . . . . . . . . . . . . . . . . . . 86 12.3.3.3 TRUNK0_H - Trunk group 0 High (Managed mode only) . . . . . . . . . . . . . . . . . . . . . . . . . . 86 12.3.3.4 TRUNK0_MODE- Trunk group 0 mode . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 86 12.3.3.5 TRUNK0_HASH0 - Trunk group 0 hash result 0 destination port number . . . . . . . . . . . . . 87 12.3.3.6 TRUNK0_HASH1 - Trunk group 0 hash result 1 destination port number . . . . . . . . . . . . . 87 12.3.3.7 TRUNK0_HASH2 - Trunk group 0 hash result 2 destination port number . . . . . . . . . . . . . 87 12.3.3.8 TRUNK0_HASH3 - Trunk group 0 hash result 3 destination port number . . . . . . . . . . . . . 87 12.3.3.9 TRUNK1_L - Trunk group 1 Low (Managed mode only) . . . . . . . . . . . . . . . . . . . . . . . . . . . 87 12.3.3.10 TRUNK1_M - Trunk group 1 Medium (Managed mode only) . . . . . . . . . . . . . . . . . . . . . . 88 12.3.3.11 TRUNK1_H - Trunk group 1 High (Managed mode only) . . . . . . . . . . . . . . . . . . . . . . . . . 88 12.3.3.12 TRUNK1_MODE - Trunk group 1 mode . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 88 12.3.3.13 TRUNK1_HASH0 - Trunk group 1 hash result 0 destination port number . . . . . . . . . . . . 88 12.3.3.14 TRUNK1_HASH1 - Trunk group 1 hash result 1 destination port number . . . . . . . . . . . . 88 12.3.3.15 TRUNK1_HASH2 - Trunk group 1 hash result 2 destination port number . . . . . . . . . . . . 88 12.3.3.16 TRUNK1_HASH3 - Trunk group 1 hash result 3 destination port number . . . . . . . . . . . . 89 12.3.3.17 TRUNK2_MODE - Trunk group 2 mode . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 89 12.3.3.18 TRUNK2_HASH0 - Trunk group 2 hash result 0 destination port number . . . . . . . . . . . . 89 12.3.3.19 TRUNK2_HASH1 - Trunk group 2 hash result 1 destination port number . . . . . . . . . . . . 89 12.3.3.20 MULTICAST_HASHn_0 - Multicast hash result 0~3 mask byte 0 . . . . . . . . . . . . . . . . . . . 90 12.3.3.21 MULTICAST_HASHn_1 - Multicast hash result 0~3 mask byte 1 . . . . . . . . . . . . . . . . . . . 90 12.3.3.22 MULTICAST_HASHn_2 - Multicast hash result 0~3 mask byte 2 . . . . . . . . . . . . . . . . . . . 90 12.3.3.23 MULTICAST_HASHn_3 - Multicast hash result 0~3 mask byte 3 . . . . . . . . . . . . . . . . . . . 90 12.3.4 (Group 3 Address) CPU Port Configuration Group . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 90 12.3.4.1 MAC0 - CPU Mac address byte 0 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 90 12.3.4.2 MAC1 - CPU Mac address byte 1 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 90 12.3.4.3 MAC2 - CPU Mac address byte 2 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 90 12.3.4.4 MAC3 - CPU Mac address byte 3 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 91 12.3.4.5 MAC4 - CPU Mac address byte 4 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 91 12.3.4.6 MAC5 - CPU Mac address byte 5 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 91 12.3.4.7 INT_MASK0 - Interrupt Mask 0 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 91 12.3.4.8 INTP_MASK0 - Interrupt Mask for MAC Port 0,1 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 92 12.3.4.9 INTP_MASKn - Interrupt Mask for MAC Ports. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 92 12.3.4.10 RQS - Receive Queue Select . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 93 12.3.4.11 RQSS - Receive Queue Status . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 93 12.3.4.12 TX_AGE - Tx Queue Aging timer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 94 12.3.5 (Group 4 Address) Search Engine Group . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 94 12.3.5.1 AGETIME_LOW - MAC address aging time Low . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 94 12.3.5.2 AGETIME_HIGH -MAC address aging time High . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 94 12.3.5.3 V_AGETIME - VLAN to Port aging time . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 94 12.3.5.4 SE_OPMODE - Search Engine Operation Mode . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 95 12.3.5.5 SCAN - SCAN Control Register (default 00) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 96 12.3.6 (Group 5 Address) Buffer Control/QOS Group . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 96 12.3.6.1 FCBAT - FCB Aging Timer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 96 12.3.6.2 QOSC - QOS Control . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 96 12.3.6.3 FCR - Flooding Control Register . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 97 12.3.6.4 AVPML - VLAN Tag Priority Map. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 98 12.3.6.5 AVPMM - VLAN Priority Map. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 98 12.3.6.6 AVPMH - VLAN Priority Map . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 98 12.3.6.7 TOSPML - TOS Priority Map . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 99
8
Zarlink Semiconductor Inc.
ZL50416
Data Sheet
Table of Contents
12.3.6.8 TOSPMM - TOS Priority Map . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 99 12.3.6.9 TOSPMH - TOS Priority Map. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 99 12.3.6.10 AVDM - VLAN Discard Map. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 99 12.3.6.11 TOSDML - TOS Discard Map . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 100 12.3.6.12 BMRC - Broadcast/Multicast Rate Control . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 100 12.3.6.13 UCC - Unicast Congestion Control . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 101 12.3.6.14 MCC - Multicast Congestion Control . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 101 12.3.6.15 PR100 - Port Reservation for 10/100 ports . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 101 12.3.6.16 SFCB - Share FCB Size . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 102 12.3.6.17 C2RS - Class 2 Reserve Size . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 102 12.3.6.18 C3RS - Class 3 Reserve Size . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 102 12.3.6.19 C4RS - Class 4 Reserve Size . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 103 12.3.6.20 C5RS - Class 5 Reserve Size . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 103 12.3.6.21 C6RS - Class 6 Reserve Size . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 103 12.3.6.22 C7RS - Class 7 Reserve Size . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 103 12.3.6.23 QOSC00~02 - Classes Byte Limit Set 0. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 103 12.3.6.24 QOSC03~05 - Classes Byte Limit Set 1. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 104 12.3.6.25 QOSC06~08 - Classes Byte Limit Set 2. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 104 12.3.6.26 QOSC09~11 - Classes Byte Limit Set 3. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 104 12.3.6.27 QOSC24~27 - Classes WFQ Credit Set 0 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 105 12.3.6.28 QOSC28~31 - Classes WFQ Credit Set 1 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 105 12.3.6.29 QOSC32~35 - Classes WFQ Credit Set 2 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 105 12.3.6.30 QOSC36~39 - Classes WFQ Credit Set 3 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 106 12.3.6.31 RDRC0 - WRED Rate Control 0 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 106 12.3.6.32 RDRC1 - WRED Rate Control 1 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 106 12.3.6.33 USER_PORT0~7)_L/H - User Define Logical Port (0~7) . . . . . . . . . . . . . . . . . . . . . . . . 107 12.3.6.34 USER_PORT_[1:0]_PRIORITY - User Define Logic Port 1 and 0 Priority . . . . . . . . . . . 108 12.3.6.35 USER_PORT_[3:2]_PRIORITY - User Define Logic Port 3 and 2 Priority . . . . . . . . . . . 108 12.3.6.36 USER_PORT_[5:4]_PRIORITY - User Define Logic Port 5 and 4 Priority . . . . . . . . . . . 108 12.3.6.37 USER_PORT_[7:6]_PRIORITY - User Define Logic Port 7 and 6 Priority . . . . . . . . . . . 108 12.3.6.38 USER_PORT_ENABLE[7:0] - User Define Logic 7 to 0 Port Enables . . . . . . . . . . . . . . 108 12.3.6.39 WELL_KNOWN_PORT[1:0]_PRIORITY- Well Known Logic Port 1 and 0 Priority . . . . . 109 12.3.6.40 WELL_KNOWN_PORT[3:2]_PRIORITY- Well Known Logic Port 3 and 2 Priority . . . . . 109 12.3.6.41 WELL_KNOWN_PORT [5:4]_PRIORITY- Well Known Logic Port 5 and 4 Priority . . . . 109 12.3.6.42 WELL_KNOWN_PORT [7:6]_PRIORITY- Well Known Logic Port 7 and 6 Priority . . . . 109 12.3.6.43 WELL KNOWN_PORT_ENABLE [7:0] - Well Known Logic 7 to 0 Port Enables . . . . . . 110 12.3.6.44 RLOWL - User Define Range Low Bit 7:0 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 110 12.3.6.45 RLOWH - User Define Range Low Bit 15:8 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 110 12.3.6.46 RHIGHL - User Define Range High Bit 7:0. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 110 12.3.6.47 RHIGHH - User Define Range High Bit 15:8 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 110 12.3.6.48 RPRIORITY - User Define Range Priority . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 110 12.3.6.49 CPUQOSC1,2,3 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 111 12.3.7 (Group 6 Address) MISC Group. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 111 12.3.7.1 MII_OP0 - MII Register Option 0 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 111 12.3.7.2 MII_OP1 - MII Register Option 1 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 111 12.3.7.3 FEN - Feature Register . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 112 12.3.7.4 MIIC0 - MII Command Register 0 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 113 12.3.7.5 MIIC1 - MII Command Register 1 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 113 12.3.7.6 MIIC2 - MII Command Register 2 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 113 12.3.7.7 MIIC3 - MII Command Register 3 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 114 12.3.7.8 MIID0 - MII Data Register 0 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 114 12.3.7.9 MIID1 - MII Data Register 1 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 114
9
Zarlink Semiconductor Inc.
ZL50416
Data Sheet
Table of Contents
12.3.7.10 LED Mode - LED Control . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 114 12.3.7.11 DEVICE Mode . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 115 12.3.7.12 CHECKSUM - EEPROM Checksum . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 115 12.3.8 (Group 7 Address) Port Mirroring Group . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 115 12.3.8.1 MIRROR1_SRC - Port Mirror source port . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 115 12.3.8.2 MIRROR1_DEST - Port Mirror destination . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 116 12.3.8.3 MIRROR2_SRC - Port Mirror source port . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 116 12.3.8.4 MIRROR2_DEST - Port Mirror destination . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 116 12.3.9 (Group F Address) CPU Access Group . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 117 12.3.9.1 GCR-Global Control Register . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 117 12.3.9.2 DCR - Device Status and Signature Register. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 118 12.3.9.3 DCR1 - Chip Status . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 118 12.3.9.4 DPST - Device Port Status Register . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 119 12.3.9.5 DTST - Data read back register. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 120 12.3.9.6 DA - Dead or Alive Register. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 120 12.4 Characteristics and Timing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 121 12.4.1 Absolute Maximum Ratings . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 121 12.4.2 DC Electrical Characteristics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 121 12.4.3 Recommended Operating Conditions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 122 12.5 AC Characteristics and Timing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 123 12.5.1 Typical Reset & Bootstrap Timing Diagram . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 123 12.5.2 Typical CPU Timing Diagram for a CPU Write Cycle. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 124 12.5.3 Typical CPU Timing Diagram for a CPU Read Cycle . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 125 12.5.4 Local Frame Buffer SBRAM Memory Interface . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 126 12.5.4.1 Local SBRAM Memory Interface A. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 126 12.5.5 Reduced Media Independent Interface . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 128 12.5.6 LED Interface . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 129 12.5.7 SCANLINK, SCANCOL Interface. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 130 12.6 MDIO Interface . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 131 12.6.1 I2C Interface. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 132 12.6.2 Synchronous Serial Interface . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 133
10
Zarlink Semiconductor Inc.
ZL50416
Data Sheet
List of Figures
Figure 1 - System Block Diagram . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1 Figure 2 - GPSI (7WS) Mode Connection Diagram . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32 Figure 3 - SCANLINK and SCANCOL Status Diagram . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 33 Figure 4 - Timing Diagram of LED Interface . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35 Figure 5 - Overview of the CPU Interface . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36 Figure 6 - Data Transfer Format for I2C Interface . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38 Figure 7 - SRAM Interface Block Diagram (DMAs for 10/100 Ports Only). . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 42 Figure 8 - Memory Configuration . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43 Figure 9 - Memory Configuration For 1 M/bank, 1 Layer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 44 Figure 10 - Memory Configuration For 2 M/bank, 2 Layers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 44 Figure 11 - Memory Configuration For 2 M/bank, 1 Layer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45 Figure 12 - Priority Classification Rule . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 49 Figure 13 - Buffer Partition Scheme Used to Implement Buffer Management . . . . . . . . . . . . . . . . . . . . . . . . . . . . 55 Figure 14 - Typical Reset & Bootstrap Timing Diagram . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 123 Figure 15 - Typical CPU Timing Diagram for a CPU Write Cycle. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 124 Figure 16 - Typical CPU Timing Diagram for a CPU Read Cycle . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 125 Figure 17 - Local Memory Interface - Input Setup and Hold Timing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 126 Figure 18 - Local Memory Interface - Output Valid Delay Timing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 126 Figure 19 - AC Characteristics - Reduced Media Independent Interface . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 128 Figure 20 - AC Characteristics - Reduced Media Independent Interface . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 128 Figure 21 - AC Characteristics - LED Interface . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 129 Figure 22 - SCANLINK, SCANCOL Output Delay Timing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 130 Figure 23 - SCANLINK, SCANCOL Setup Timing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 130 Figure 24 - MDIO Input Setup and Hold Timing. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 131 Figure 25 - MDIO Output Delay Timing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 131 Figure 26 - I2C Input Setup Timing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 132 Figure 27 - I2C Output Delay Timing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 132 Figure 28 - Serial Interface Setup Timing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 133 Figure 29 - Serial Interface Output Delay Timing. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 133
11
Zarlink Semiconductor Inc.
ZL50416 1.0
1.1 1.1.1
1 A 2 3 LA_D 4 LA_D 1 LA_C LK VSSA LA_D 0 LA_D 17 LA_D 16 RESI N# LA_D 3 LA_D 2 LA_D 19 LA_D 18
Data Sheet
BGA and Ball Signal Descriptions
BGA Views (Top-View) Encapsulated view in managed mode
4 LA_D 7 LA_D 6 LA_D 5 LA_D 21 LA_D 20 5 LA_D 10 LA_D 9 LA_D 8 LA_D 23 LA_D 22 6 LA_D 13 LA_D 12 LA_D 11 LA_D 25 LA_D 24 7 LA_D 15 LA_D 14 LA_A 3 LA_D 27 LA_D 26 8 LA_A 4 LA_A DSC# LA_O E# LA_D 29 LA_D 28 9 LA_O E0# LA_O E1# 10 LA_A 8 LA_A 7 11 LA_A 13 LA_A 12 LA_A 11 LA_A 10 LA_A 9 12 LA_A 16 LA_A 15 LA_A 14 LA_W E0# LA_W E1# 13 LA_A 19 LA_A 18 LA_A 17 LD_D 49 LA_D 48 VCC 14 LA_D 33 LA_D 32 LA_A 20 LA_D 51 LA_D 50 VCC 15 LA_D 36 LA_A 35 LA_D 34 LA_D 53 LA_D 52 VCC 16 LA_D 39 LA_D 38 LA_D 37 LA_D 55 LA_D 54 VCC 17 LA_D 42 LA_A 41 LA_D 40 LA_D 57 LA_D 56 VCC 18 LA_D 45 LA_D 44 LA_D 43 LA_D 59 LA_D 58 19 P_DA TA13 P_DA TA14 P_DA TA15 LA_D 61 LA_D 60 20 P_DA TA10 P_DA TA11 P_DA TA12 LA_D 63 P_DA TA8 21 P_DA TA7 LA_D 62 P_DA TA9 LA_D 47 LA_D 46 22 P_DA TA4 P_DA TA5 P_A2 23 P_DA TA1 P_DA TA2 P_DA TA3 24 P_A1 25 P_A0 26 P_WE # 27 TSTO UT7 TSTO UT8 TSTO UT9 TSTO UT10 TSTO UT3 TSTO UT4 TSTO UT5 TSTO UT6 TSTO UT0 TSTO UT1 TSTO UT2 28 29 A
B
P_DA TA6 P_DA TA0 TSTO UT14 TSTO UT15
P_INT P_RD # # P_CS # TSTO UT13 TSTO UT11 TSTO UT12
B
C
LA_W T_MO E# DE1 LA_D 31 LA_D 30 LA_A 6 LA_A 5
C
D
SCAN SCAN COL CLK NC SCAN LNK
D
E
SCLK
RSVD RSVD SCAN MD
E
F
VDDA
SCAN RSVD RSVD EN
RSVD RSVD RSVD RSVD RSVD
F
G
RSVD RESO RSVD RSVD RSVD UT# RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD VCC VCC VCC VDD VDD VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VDD VDD VCC VCC VCC VDD VDD VDD VDD
RSVD RSVD RSVD RSVD RSVD
G
H J K L M N P R
RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD NC NC NC NC MDIO MDC RSVD RSVD M_CL K
H J K L M N P R
T U
RSVD RSVD RSVD RSVD RSVD RSVD RSVD T_MO RSVD RSVD DE0 RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD
VCC VCC VDD
VSS VSS
VSS VSS
VSS VSS
VSS VSS
VSS VSS
VSS VSS
VSS VSS VDD
VCC VCC
RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD
T U
V W Y
VDD
VSS
VSS
VSS
VSS
VSS
VSS
VSS
VDD
RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD
V W Y
VDD
VDD
VDD
VDD
RSVD RSVD RSVD RSVD RSVD
AA RSVD RSVD RSVD RSVD RSVD AB RSVD RSVD RSVD RSVD RSVD AC RSVD RSVD RSVD RSVD RSVD AD RSVD RSVD RSVD RSVD RSVD AE M0_T XEN M0_R XD1 M1_T XEN M0_T XD0 M0_R XD0 M1_T XD0 M1_R XD0 M0_T XD1 M0_C RS M1_T XD1 M1_C RS M1_R XD1 1 2 3 M3_T XD1 M3_T XD0 M2_T XD1 M2_T XD0 M2_T XEN 4 M3_T XEN M3_C RS M2_C RS M2_R XD0 M2_R XD1 5 M3_R XD0 M3_R XD1 M4_T XD1 M4_T XD0 M4_T XEN 6 M5_T XD1 M5_T XD0 M4_C RS M4_R XD0 M4_R XD1 7 M5_T XEN M5_C RS M6_T XD1 M6_T XD0 M6_T XEN 8 M5_R XD0 M5_R XD1 M6_C RS M7_R XD0 M7_R XD1 9 M8_T XD1 M8_T XD0 M7_T XD1 M7_T XD0 M7_T XEN 10 M8_T XEN M8_C RS M7_C RS M7_R XD0 M7_R XD1 11 M8_R XD0 M8_R XD1 M9_T XD1 M9_T XD0 M9_T XEN 12 VCC M10_ TXD1 M10_ TXD0 M9_C RS M9_R XD0 M9_R XD1 13 VCC M10_ TXEN M10_ CRS M11_ TXD1 M11_ TXD0 M11_ TXEN 14 VCC M10_ RXD0 M10_ RXD1 M11_ CRS M11_ RXD0 M11_ RXD1 15 VCC M13_ TXD1 M13_ TXD0 M12_ TXD1 M12_ TXD0 M12_ TXEN 16 VCC RSVD M15_ TXD1 M13_ RXD1 M14_ TXD1 M14_ TXD0 M14_ TXEN 18 RSVD M15_ TXEN RSVD M15_ RXD0 M15_ RXD1
RSVD RSVD RSVD RSVD RSVD AA RSVD RSVD RSVD RSVD RSVD AB RSVD RSVD RSVD RSVD RSVD AC RSVD RSVD RSVD RSVD RSVD AD RSVD RSVD RSVD RSVD RSVD RSVD RSVD NC AE
AF
M13_ CRS M12_ CRS M12_ RXD0 M12_ RXD1 17
M14_ CRS M15_ TXD0 M14_ RXD0 M14_ RXD1 19
RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD AF
AG
RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD AG
AH
M13_ RXD0 RSVD
M15_ CRS M13_ TXEN 21
RSVD RSVD RSVD RSVD RSVD RSVD RSVD
AH
AJ
RSVD RSVD RSVD RSVD RSVD RSVD
AJ
20
22
23
24
25
26
27
28
29
12
Zarlink Semiconductor Inc.
ZL50416
1.1.2
1 A 2 3 LA_D 4 LA_D 1 LA_C LK VSSA LA_D 0 LA_D 17 LA_D 16 RESI N# LA_D 3 LA_D 2 LA_D 19 LA_D 18
Data Sheet
Encapsulated view in unmanaged mode
4 LA_D 7 LA_D 6 LA_D 5 LA_D 21 LA_D 20 5 LA_D 10 LA_D 9 LA_D 8 LA_D 23 LA_D 22 6 LA_D 13 LA_D 12 LA_D 11 LA_D 25 LA_D 24 7 LA_D 15 LA_D 14 LA_A 3 LA_D 27 LA_D 26 8 LA_A 4 LA_A DSC# LA_O E# LA_D 29 LA_D 28 9 LA_O E0# LA_O E1# 10 LA_A 8 LA_A 7 11 LA_A 13 LA_A 12 LA_A 11 LA_A 10 LA_A 9 12 LA_A 16 LA_A 15 LA_A 14 LA_W E0# LA_W E1# 13 LA_A 19 LA_A 18 LA_A 17 LD_D 49 LA_D 48 VCC 14 LA_D 33 LA_D 32 LA_A 20 LA_D 51 LA_D 50 VCC 15 LA_D 36 LA_A 35 LA_D 34 LA_D 53 LA_D 52 VCC 16 LA_D 39 LA_D 38 LA_D 37 LA_D 55 LA_D 54 VCC 17 LA_D 42 LA_A 41 LA_D 40 LA_D 57 LA_D 56 VCC 18 LA_D 45 LA_D 44 LA_D 43 LA_D 59 LA_D 58 19 OE_C LK0 OE_C LK1 OE_C LK2 LA_D 61 LA_D 60 20 LA_C LK0 LA_C LK1 LA_C LK2 LA_D 63 RSVD 21 TRUN K1 LA_D 62 P_D 22 MIRR OR4 MIRR OR5 TRUN K0 23 MIRR OR1 MIRR OR2 MIRR OR3 24 SCL 25 SDA 26 STRO BE D0 27 TSTO UT7 TSTO UT8 TSTO UT9 TSTO UT10 TSTO UT3 TSTO UT4 TSTO UT5 TSTO UT6 TSTO UT0 TSTO UT1 TSTO UT2 28 29 A
B
RSVD RSVD
B
C
LA_W T_MO E# DE1 LA_D 31 LA_D 30 LA_A 6 LA_A 5
MIRR OR0 TSTO UT14 TSTO UT15
AUTO FD TSTO UT13
TSTO UT11 TSTO UT12
C
D
LA_D 47 LA_D 46
SCAN SCAN COL CLK NC SCAN LNK
D
E
SCLK
RSVD RSVD SCAN MD
E
F
VDDA
SCAN RSVD RSVD EN
RSVD RSVD RSVD RSVD RSVD
F
G
RSVD RESO RSVD RSVD RSVD UT# RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD VCC VCC VCC VDD VDD VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VDD VDD VCC VCC VCC VDD VDD VDD VDD
RSVD RSVD RSVD RSVD RSVD
G
H J K L M N P R
RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD NC NC NC NC MDIO MDC RSVD RSVD M_CL K
H J K L M N P R
T U
RSVD RSVD RSVD RSVD RSVD RSVD RSVD T_MO RSVD RSVD DE0 RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD
VCC VCC VDD
VSS VSS
VSS VSS
VSS VSS
VSS VSS
VSS VSS
VSS VSS
VSS VSS VDD
VCC VCC
RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD
T U
V W Y
VDD
VSS
VSS
VSS
VSS
VSS
VSS
VSS
VDD
RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD
V W Y
VDD
VDD
VDD
VDD
RSVD RSVD RSVD RSVD RSVD
AA RSVD RSVD RSVD RSVD RSVD AB RSVD RSVD RSVD RSVD RSVD AC RSVD RSVD RSVD RSVD RSVD AD RSVD RSVD RSVD RSVD RSVD AE M0_T XEN M0_R XD1 M1_T XEN M0_T XD0 M0_R XD0 M1_T XD0 M1_R XD0 M0_T XD1 M0_C RS M1_T XD1 M1_C RS M1_R XD1 1 2 3 M3_T XD1 M3_T XD0 M2_T XD1 M2_T XD0 M2_T XEN 4 M3_T XEN M3_C RS M2_C RS M2_R XD0 M2_R XD1 5 M3_R XD0 M3_R XD1 M4_T XD1 M4_T XD0 M4_T XEN 6 M5_T XD1 M5_T XD0 M4_C RS M4_R XD0 M4_R XD1 7 M5_T XEN M5_C RS M6_T XD1 M6_T XD0 M6_T XEN 8 M5_R XD0 M5_R XD1 M6_C RS M7_R XD0 M7_R XD1 9 M8_T XD1 M8_T XD0 M7_T XD1 M7_T XD0 M7_T XEN 10 M8_T XEN M8_C RS M7_C RS M7_R XD0 M7_R XD1 11 M8_R XD0 M8_R XD1 M9_T XD1 M9_T XD0 M9_T XEN 12 VCC M10_ TXD1 M10_ TXD0 M9_C RS M9_R XD0 M9_R XD1 13 VCC M10_ TXEN M10_ CRS M11_ TXD1 M11_ TXD0 M11_ TXEN 14 VCC M10_ RXD0 M10_ RXD1 M11_ CRS M11_ RXD0 M11_ RXD1 15 VCC M13_ TXD1 M13_ TXD0 M12_ TXD1 M12_ TXD0 M12_ TXEN 16 VCC RSVD M15_ TXD1 M13_ RXD1 M14_ TXD1 M14_ TXD0 M14_ TXEN 18 RSVD M15_ TXEN RSVD M15_ RXD0 M15_ RXD1
RSVD RSVD RSVD RSVD RSVD AA RSVD RSVD RSVD RSVD RSVD AB RSVD RSVD RSVD RSVD RSVD AC RSVD RSVD RSVD RSVD RSVD AD RSVD RSVD RSVD RSVD RSVD RSVD RSVD NC AE
AF
M13_ CRS M12_ CRS M12_ RXD0 M12_ RXD1 17
M14_ CRS M15_ TXD0 M14_ RXD0 M14_ RXD1 19
RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD AF
AG
RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD AG
AH
M13_ RXD0 RSVD
M15_ CRS M13_ TXEN 21
RSVD RSVD RSVD RSVD RSVD RSVD RSVD
AH
AJ
RSVD RSVD RSVD RSVD RSVD RSVD
AJ
20
22
23
24
25
26
27
28
29
13
Zarlink Semiconductor Inc.
ZL50416
1.2 Ball - Signal Descriptions
Data Sheet
All pins are CMOS type; all Input Pins are 5 Volt tolerance; and all Output Pins are 3.3 CMOS drive.
Notes: # = Active low signal Weak internal pull-up/down resistors are nominal 100k ohm Input = Input signal In-ST = Input signal with Schmitt-Trigger Output = Output signal (Tri-State driver) Out-OD = Output signal with Open-Drain driver I/O-TS = Input & Output signal with Tri-State driver I/O-OD = Input & Output signal with Open-Drain driver
Ball No(s)
Symbol
I/O
Description
CPU BUS Interface in Managed Mode C19, B19, A19, C20, B20, A20, C21, E20, A21, B24, B22, A22, C23, B23, A23, C24 C22, A24, A25 A26 B26 C25 B25 P_DATA[15:0] I/O-TS with weak internal pull-up (except P_DATA[7:6] with weak internal pull-down) Input Input with weak internal pull-up Input with weak internal pull-up Input with weak internal pull-up Output Processor Bus Data Bit [15:0]. P_DATA[7:0] is used in 8-bit mode.
P_A[2:0] P_WE# P_RD# P_CS# P_INT#
Processor Bus Address Bit [2:0] CPU Bus-Write Enable CPU Bus-Read Enable Chip Select CPU Interrupt
CPU BUS Interface in Unmanaged Mode - Use I2C and Serial control interface to configure the system A24 A25 A26 B26 C25 SCL SDA STROBE DATAIN (D0) DATAOUT (AUTOFD) Output I/O-TS with weak internal pull-up Input with weak internal pull-up Input with weak internal pull-up Output with weak internal pull-up I2C Data Clock I2C Data I/O Serial Strobe Pin Serial Data Input (D0) Serial Data Output (AutoFD)
14
Zarlink Semiconductor Inc.
ZL50416
Ball No(s) Frame Buffer Interface D20, B21, D19, E19,D18, E18, D17, E17, D16, E16, D15, E15, D14, E14, D13, E13, D21, E21, A18, B18, C18, A17, B17, C17, A16, B16, C16, A15, B15, C15, A14, B14, D9, E9, D8, E8, D7, E7, D6, E6, D5, E5, D4, E4, D3, E3, D2, E2, A7, B7, A6, B6, C6, A5, B5, C5, A4, B4, C4, A3, B3, C3, B2, C2 C14, A13, B13, C13, A12, B12, C12, A11, B11, C11, D11, E11, A10, B10, D10, E10, A8, C7 B8 C1 C9 D12 LA_D[63:0] I/O-TS with weak internal pull-up Symbol I/O Description
Data Sheet
Frame Bank A- Data Bit [63:0]
LA_A[20:3]
Output
Frame Bank A - Address Bit [20:3]
LA_ADSC# LA_CLK LA_WE# LA_WE0#
Output with weak internal pull-up Output Output with weak internal pull-up Output with weak internal pull-up Output with weak internal pull-up Output with weak internal pull-up Output with weak internal pull-up Output with weak internal pull-up
Frame Bank A Address Status Control Frame Bank A Clock Input Frame Bank A Write Chip Select for one layer SRAM configuration Frame Bank A Write Chip Select for lower layer of two layers SRAM configuration Frame Bank A Write Chip Select for upper layer of two layers SRAM configuration Frame Bank A Read Chip Select for one bank SRAM configuration Frame Bank A Read Chip Select for lower layer of two layers SRAM configuration Frame Bank A Read Chip Select for upper layer of two layers SRAM configuration
E12
LA_WE1#
C8 A9
LA_OE# LA_OE0#
B9
LA_OE1#
Fast Ethernet Access Ports [15:0] RMII R28 P28 M_MDC M_MDIO Output I/O-TS with weak internal pull-up MII Management Data Clock - (Common for all MII Ports [15:0]) MII Management Data I/O - (Common for all MII Ports -[15:0]))
15
Zarlink Semiconductor Inc.
ZL50416
Ball No(s) R29 AF21, AJ19, AF18, AJ17, AJ15, AF15, AJ13, AF12, AJ11, AJ9, AF9, AJ7, AF6, AJ5, AJ3, AF1 AE21, AH19, AH20, AH17, AH15, AE15, AH13, AE12, AH11, AH9, AE9, AH7, AE6, AH5, AH2, AF2 AH21, AF19, AF17, AG17, AG15, AF14, AG13, AF11, AG11, AG9, AF8, AG7, AF5, AG5, AH3, AF3 AE20, AJ18, AJ21, AJ16, AJ14, AE14, AJ12, AE11, AJ10, AJ8, AE8, AJ6, AE5, AJ4, AG1, AE1 AE18, AG18, AE16, AG16, AG14, AE13, AG12, AE10, AG10, AG8, AE7, AG6, AE4, AG4, AG3, AE3 AG19, AH18, AF16, AH16, AH14, AF13, AH12, AF10, AH10, AH8, AF7, AH6, AF4, AH4, AG2, AE2 LED Interface C29 D29 E29 B27, A27, E28, D28, C28, B28 C27 D27 LED_CLK/ TSTOUT0 LED_SYN/ TSTOUT1 LED_BIT/ TSTOUT2 TSTOUT[8:3] INIT_DONE/ TSTOUT9 INIT_START/ TSTOUT10 I/O-TS with weak internal pull-up I/O-TS with weak internal pull-up I/O-TS with weak internal pull-up I/O- TS with pull up I/O-TS with weak internal pull-up I/O-TS with weak internal pull-up Symbol M_CLK M[15:0]_RXD[1] Input Input with weak internal pull-up I/O Description Reference Input Clock
Data Sheet
Ports [15:0] - Receive Data Bit [1]
M[15:0]_RXD[0]
Input with weak internal pull-up
Ports [15:0] - Receive Data Bit [0]
M[15:0]_CRS_DV
Input with weak internal pull-down
Ports [15:0] - Carrier Sense and Receive Data Valid
M[15:0]_TXEN
I/O-TS, slew with weak internal pull-up
Ports [15:0] - Transmit Enable Bootstrap option for RMII/GPSI
M[15:0]_TXD[1]
Output, slew
Ports [15:0] - Transmit Data Bit [1]
M[15:0]_TXD[0]
Output, slew
Ports [15:0] - Transmit Data Bit [0]
LED Serial Interface Output Clock LED Output Data Stream Envelope LED Serial Data Output Stream Reserved System start operation Start initialization
16
Zarlink Semiconductor Inc.
ZL50416
Ball No(s) C26 D26 D25 D24 E24 Test Facility U3, C10 T_MODE0, T_MODE1 I/O-TS Must be externally pulled-up Symbol CHECKSUM_OK/ TSTOUT11 FCB_ERR/ TSTOUT12 MCT_ERR/ TSTOUT13 BIST_IN_PRC/ TSTOUT14 BIST_DONE/ TSTOUT15 I/O I/O-TS with weak internal pull-up I/O-TS with weak internal pull-up I/O-TS with weak internal pull-up I/O-TS with weak internal pull-up I/O-TS with weak internal pull-up Description EEPROM read OK FCB memory self test fail MCT memory self test fail
Data Sheet
Processing memory self test Memory self test done
Test Pins. Manufacturing test option. 00 - Test mode - Set test mode upon reset, and provides NANDTree test output during test mode 01 - Reserved - Do not use 10 - Reserved - Do not use 11 - Normal mode Use external pull-ups for normal mode
F3
SCAN_EN
Input with weak internal pull-down
Scan Enable. Manufacturing test option. Should not be connected for proper operation.
E27
SCANMODE
Input with weak internal pull-down
Scan Mode Enable. Manufacturing test option. 1 - Enable Test mode 0 - Normal mode (open) Should not be connected for proper operation.
System Clock, Power, and Ground Pins E1 K12, K13, K17,K18 M10, N10, M20, N20, U10, V10, U20, V20, Y12, Y13, Y17, Y18 F13, F14, F15, F16, F17, N6, P6, R6, T6, U6, N24, P24, R24, T24, U24, AD13, AD14, AD15, AD16, AD17 SCLK VDD Input Power System Clock at 100 MHz +2.5 Volt DC Supply
VCC
Power
+3.3 Volt DC Supply
17
Zarlink Semiconductor Inc.
ZL50416
Ball No(s) M12, M13, M14, M15, M16, M17, M18, N12, N13, N14, N15, N16, N17, N18, P12, P13, P14, P15, P16, P17, P18, R12, R13, R14, R15, R16, R17, R18, T12, T13, T14, T15, T16, T17, T18, U12, U13, U14, U15, U16, U17, U18, V12, V13, V14, V15, V16, V17, V18, F1 D1 MISC D22 D23 E23 F2 G2 E22, N27, N28, P27, R27, AE29 SCANCOL SCANCLK SCANLINK RESIN# RESETOUT# NC I/O Output I/O Input Output NC VSS Symbol I/O Power Ground Ground Description
Data Sheet
VDDA VSSA
Analog Power Analog Ground
Analog +2.5 Volt DC Supply Analog Ground
Scans the Collision signal of Home PHY Clock for scanning Home PHY collision and link Link up signal from Home PHY Reset Input Reset PHY No Internal Connect
18
Zarlink Semiconductor Inc.
ZL50416
Ball No(s) , F4, F5, G4, G5, H4, H5, J4, J5, K4, K5, L4, L5, M4, M5, N4, N5, G3, H1, H2, H3, J1, J2, J3, K1, K2, K3, L1, L2, L3, M1, M2, M3, U4, U5, V4, V5, W4, W5, Y4, Y5, AA4, AA5, AB4, AB5, AC4, AC5, AD4, AD5, W1, Y1, Y2, Y3, AA1, AA2, AA3, AB1, AB2, AB3, AC1, AC2, AC3, AD1, AD2, AD3, N3, N2, N1, P3, P2, P1, R5, R4, R3, R2, R1, T5, T4, T3, T2, T1, W3, W2, V1, G1, V3, P4, P5, V2, U1, U2, U26, U25, V26, V25, W26, W25, U27, V29, V28, V27, W29, W28, G26, G25, H26, H25, J26, J25, G27,H29, H28, H27, J29, J28, AC29, AE28, AJ27, AF27, AJ25, AF24, AH23, AE19, AC28, AF28, AH27, AE27, AH25, AE24, AF22, AF20, AC27, AF29, AG27, AF26, AG25, AG23, AF23, AG21, AD29, AG28, AJ26, AE26, AJ24, AE23, AJ22, AJ20, AD27, AH28, AG26, AE25, AG24, AE22, AJ23, AG20, AD28, AG29, AH26, AF25, AH24, AG22, AH22, AE17 Symbol RSVD N/A I/O Description
Data Sheet
Reserved. Leave unconnected.
Bootstrap Pins (1= pull-up 0= pull-down) (Default = 1 due to weak internal pull-ups) After reset TSTOUT0 to TSTOU15 are used by the LED interface. C29 TSTOUT0 Input (Reset Only) with weak internal pull-up Input (Reset Only) with weak internal pull-up Reserved
D29
TSTOUT1
RMII MAC Power Saving Enable 1 - power saving 0 - No power saving
19
Zarlink Semiconductor Inc.
ZL50416
Ball No(s) E29 Symbol TSTOUT2 I/O Input (Reset Only) with weak internal pull-up Must be externally pulled-down B28 TSTOUT3 Input (Reset Only) with weak internal pull-up Input (Reset Only) with weak internal pull-up Input (Reset Only) with weak internal pull-up Input (Reset Only) with weak internal pull-up Reserved Description
Data Sheet
Manufacturing Option. Must be '0'.
C28
TSTOUT4
Reserved
D28
TSTOUT5
Scan Speed: 1/4 SCLK or SCLK 1 - SCLK 0 - 1/4 SCLK (HPNA) CPU Port Mode 1 - 16 bit Bus Mode 0 - 8 bit Bus Mode Only applicable in managed mode (TSTOUT14='0').
E28
TSTOUT6
A27
TSTOUT7
Input (Reset Only) with weak internal pull-up
Memory Size 1 - 128 K x 32 or 128 K x 64 (1 M total) 0 - -256 K x 32 or 256 K x 64 (2 M total) EEPROM Installed 1 - EEPROM not installed 0 - EEPROM installed Only applicable in unmanaged mode.
B27
TSTOUT8
Input (Reset Only) with weak internal pull-up
C27
TSTOUT9
Input (Reset Only) with weak internal pull-up Input (Reset Only) with weak internal pull-up Must be externally pulled-down
MCT Aging 1 - MCT aging enable 0 - MCT aging disable Manufacturing Option. Must be '0'.
D27
TSTOUT10
C26
TSTOUT11
Input (Reset Only) with weak internal pull-up
Timeout Reset 1 - Time out reset enable 0 - Time out reset disable If enabled, issue reset if any state machine did not go back to idle for 5sec.
20
Zarlink Semiconductor Inc.
ZL50416
Ball No(s) D26 Symbol TSTOUT12 I/O Input (Reset Only) with weak internal pull-up Input (Reset Only) with weak internal pull-up Input (Reset Only) with weak internal pull-up Input (Reset Only) with weak internal pull-up Input (Reset Only) with weak internal pull-up Description
Data Sheet
Manufacturing Option. Must be '1'.
D25
TSTOUT13
FDB RAM depth (1 or 2 layers) 1 - 1 layer 0 - 2 layer CPU installed 1 - CPU not installed 0 - CPU installed SRAM Test Mode 1 - Normal operation 0 - Enable test mode 1 - RMII 0 - GPSI
D24
TSTOUT14
E24
TSTOUT15
AD29, AG28, AJ26, AE26, AJ24, AE23, AJ22, AJ20, AE20, AJ18, AJ21, AJ16, AJ14, AE14, AJ12, AE11, AJ10, AJ8, AE8, AJ6, AE5, AJ4, AG1, AE1 C21
M[15:0]_TXEN
P_D[9] (P_D)
Input (Reset Only) with weak internal pull-up Must be externally pulled-down
Manufacturing Option. Must be '0'.
C19, B19, A19
P_D[15:13] (OE_CLK[2:0])
Input (Reset Only) with weak internal pull-up Recommend 001 with external pull-downs on P_D[15:14] (OE_CLK[2:1]).
Programmable delay for internal OE_CLK from SCLK input. The OE_CLK is used for generating the OE0 and OE1 signals. Suggested value is 001. Programmable delay for LA_CLK from internal OE_CLK. The LA_CLK delay from SCLK is the sum of the delay programmed in here and the delay in P_D[15:13] (OE_CLK[2:0]). Suggested value is 011.
C20, B20, A20
P_D[12:10] (L_CLK[2:0])
Input (Reset Only) with weak internal pull-up Recommend 011 with external pull-down on P_D[12] (L_CLK[2]).
B22, A22, C23, B23, A23, C24
P_D[5:0] (MIRROR[5:0])
Input (Reset Only) with weak internal pull-up
Dedicated Port Mirror Mode. The first 5 bits ([4:0]) select the port to be mirrored. The last bit ([5]) selects either ingress or egress data.
21
Zarlink Semiconductor Inc.
ZL50416
Ball No(s) C22 Symbol P_A[0] (TRUNK0) I/O Input (Reset Only) with weak internal pull-down Input (Reset Only) with weak internal pull-down Description Trunk Group 0 Enable 0 - Disable 1 - Enable Trunk Group 1 Enable 0 - Disable 1 - Enable
Data Sheet
A21
P_D[7] (TRUNK1)
22
Zarlink Semiconductor Inc.
ZL50416
1.3 Ball - Signal Name
Signal Name LA_D[63] LA_D[62] LA_D[61] LA_D[60] LA_D[59] LA_D[58] LA_D[57] LA_D[56] LA_D[55] LA_D[54] LA_D[53] LA_D[52] LA_D[51] LA_D[50] LA_D[49] LA_D[48] LA_D[47] LA_D[46] LA_D[45] LA_D[44] LA_D[43] LA_D[42] LA_D[41] LA_D[40] LA_D[39] LA_D[38] LA_D[37] LA_D[36] LA_D[35] LA_D[34] LA_D[33] LA_D[32] Ball No. D3 E3 D2 E2 A7 B7 A6 B6 C6 A5 B5 C5 A4 B4 C4 A3 B3 C3 B2 C2 C14 A13 B13 C13 A12 B12 C12 A11 B11 C11 D11 E11 Signal Name LA_D[19] LA_D[18] LA_D[17] LA_D[16] LA_D[15] LA_D[14] LA_D[13] LA_D[12] LA_D[11] LA_D[10] LA_D[9] LA_D[8] LA_D[7] LA_D[6] LA_D[5] LA_D[4] LA_D[3] LA_D[2] LA_D[1] LA_D[0] LA_A[20] LA_A[19] LA_A[18] LA_A[17] LA_A[16] LA_A[15] LA_A[14] LA_A[13] LA_A[12] LA_A[11] LA_A[10] LA_A[9] Ball No. A9 B9 F4 F5 G4 G5 H4 H5 J4 J5 K4 K5 L4 L5 M4 M5 N4 N5 G3 H1 H2 H3 J1 J2 J3 K1 K2 K3 L1 L2 L3 M1
Data Sheet
Ball No. D20 B21 D19 E19 D18 E18 D17 E17 D16 E16 D15 E15 D14 E14 D13 E13 D21 E21 A18 B18 C18 A17 B17 C17 A16 B16 C16 A15 B15 C15 A14 B14
Signal Name LA_OE0# LA_OE1# RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD
23
Zarlink Semiconductor Inc.
ZL50416
Ball No. D9 E9 D8 E8 D7 E7 D6 E6 D5 E5 D4 E4 AB4 AB5 AC4 AC5 AD4 AD5 W1 Y1 Y2 Y3 AA1 AA2 AA3 AB1 AB2 AB3 AC1 AC2 AC3 AD1 AD2 Signal Name LA_D[31] LA_D[30] LA_D[29] LA_D[28] LA_D[27] LA_D[26] LA_D[25] LA_D[24] LA_D[23] LA_D[22] LA_D[21] LA_D[20] RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD Ball No. A10 B10 D10 E10 A8 C7 B8 C1 C9 D12 E12 C8 U2 R28 P28 R29 AC29 AE28 AJ27 AF27 AJ25 AF24 AH23 AE19 AF21 AJ19 AF18 AJ17 AJ15 AF15 AJ13 AF12 AJ11 Signal Name LA_A[8] LA_A[7] LA_A[6] LA_A[5] LA_A[4] LA_A[3] LA_DSC# LA_CLK LA_WE# LA_WE0# LA_WE1# LA_OE# RSVD MDC MDIO M_CLK RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD M[15]_RXD[1] M[14]_RXD[1] M[13]_RXD[1] M[12]_RXD[1] M[11]_RXD[1] M[10]_RXD[1] M[9]_RXD[1] M[8]_RXD[1] M[7]_RXD[1] Ball No. M2 M3 U4 U5 V4 V5 W4 W5 Y4 Y5 AA4 AA5 AH7 AE6 AH5 AH2 AF2 AC27 AF29 AG27 AF26 AG25 AG23 AF23 AG21 AH21 AF19 AF17 AG17 AG15 AF14 AG13 AF11 RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD M[4]_RXD[0] M[3]_RXD[0] M[2]_RXD[0] M[1]_RXD[0] M[0]_RXD[0] RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD
Data Sheet
Signal Name
M[15]_CRS_DV M[14]_CRS_DV M[13]_CRS_DV M[12]_CRS_DV M[11]_CRS_DV M[10]_CRS_DV M[9]_CRS_DV M[8]_CRS_DV
24
Zarlink Semiconductor Inc.
ZL50416
Ball No. AD3 N3 N2 N1 P3 P2 P1 R5 R4 R3 R2 R1 T5 T4 T3 T2 T1 W3 W2 V1 G1 V3 P4 P5 V2 U1 AE8 AJ6 AE5 AJ4 AG1 AE1 AD27 Signal Name RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD M[5]_TXEN M[4]_TXEN M[3]_TXEN M[2]_TXEN M[1]_TXEN M[0]_TXEN RSVD Ball No. AJ9 AF9 AJ7 AF6 AJ5 AJ3 AF1 AC28 AF28 AH27 AE27 AH25 AE24 AF22 AF20 AE21 AH19 AH20 AH17 AH15 AE15 AH13 AE12 AH11 AH9 AE9 AH8 AF7 AH6 AF4 AH4 AG2 AE2 Signal Name M[6]_RXD[1] M[5]_RXD[1] M[4]_RXD[1] M[3]_RXD[1] M[2]_RXD[1] M[1]_RXD[1] M[0]_RXD[1] RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD M[15]_RXD[0] M[14]_RXD[0] M[13]_RXD[0] M[12]_RXD[0] M[11]_RXD[0] M[10]_RXD[0] M[9]_RXD[0] M[8]_RXD[0] M[7]_RXD[0] M[6]_RXD[0] M[5]_RXD[0] M[6]_TXD[0] M[5]_TXD[0] M[4]_TXD[0] M[3]_TXD[0] M[2]_TXD[0] M[1]_TXD[0] M[0]_TXD[0] Ball No. AG11 AG9 AF8 AG7 AF5 AG5 AH3 AF3 AD29 AG28 AJ26 AE26 AJ24 AE23 AJ22 AJ20 AE20 AJ18 AJ21 AJ16 AJ14 AE14 AJ12 AE11 AJ10 AJ8 G27 H29 H28 H27 J29 J28 J27
Data Sheet
Signal Name M[7]_CRS_DV M[6]_CRS_DV M[5]_CRS_DV M[4]_CRS_DV M[3]_CRS_DV M[2]_CRS_DV M[1]_CRS_DV M[0]_CRS_DV RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD M[15]_TXEN M[14]_TXEN M[13]_TXEN M[12]_TXEN M[11]_TXEN M[10]_TXEN M[9]_TXEN M[8]_TXEN M[7]_TXEN M[6]_TXEN RSVD RSVD RSVD RSVD RSVD RSVD RSVD
25
Zarlink Semiconductor Inc.
ZL50416
Ball No. AH28 AG26 AE25 AG24 AE22 AJ23 AG20 AE18 AG18 AE16 AG16 AG14 AE13 AG12 AE10 AG10 AG8 AE7 AG6 AE4 AG4 AG3 AE3 AD28 AG29 AH26 AF25 AH24 AG22 AH22 AE17 AG19 AH18 Signal Name RSVD RSVD RSVD RSVD RSVD RSVD RSVD M[15]_TXD[1] M[14]_TXD[1] M[13]_TXD[1] M[12]_TXD[1] M[11]_TXD[1] M[10]_TXD[1] M[9]_TXD[1] M[8]_TXD[1] M[7]_TXD[1] M[6]_TXD[1] M[5]_TXD[1] M[4]_TXD[1] M[3]_TXD[1] M[2]_TXD[1] M[1]_TXD[1] M[0]_TXD[1] RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD M[15]_TXD[0] M[14]_TXD[0] Ball No. U26 U25 V26 V25 W26 W25 Y27 Y26 AA26 AA25 AB26 AB25 AC26 AC25 AD26 AD25 U27 V29 V28 V27 W29 W28 W27 Y29 Y28 Y25 AA29 AA28 AA27 AB29 AB28 AB27 R26 Signal Name RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD Ball No. K29 K28 K27 L29 L28 L27 M29 M28 M27 G26 G25 H26 H25 J26 J25 K25 K26 M25 L26 M26 L25 N26 N25 P26 P25 F28 G28 E25 G29 F29 F26 E26 F25 RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD RSVD
Data Sheet
Signal Name
26
Zarlink Semiconductor Inc.
ZL50416
Ball No. AF16 AH16 AH14 AF13 AH12 AF10 AH10 B27 A27 E28 D28 C28 B28 E29 D29 C29 N29 P29 F3 E1 U3 C10 B24 A21 C22 A26 B26 C25 A24 A25 Signal Name M[13]_TXD[0] M[12]_TXD[0] M[11]_TXD[0] M[10]_TXD[0] M[9]_TXD[0] M[8]_TXD[0] M[7]_TXD[0] TSTOUT[8] TSTOUT[7] TSTOUT[6] TSTOUT[5] TSTOUT[4] TSTOUT[3] LED_BIT/TSTOUT[2] LED_SYN/TSTOUT[ 1] LED_CLK/TSTOUT[0 ] RSVD RSVD SCAN_EN SCLK T_MODE0 T_MODE1 P_DATA6/RSVD P_DATA7/TRUNK1 P_A2/TRUNK0 P_WE/STROBE P_RD/D0 P_CS/AUTOFD P_A1/SCL P_A0/SDA Ball No. T25 T26 T28 U28 R25 U29 T29 U18 V12 V13 V14 V15 V16 V17 V18 N14 N15 C19 B19 A19 P12 P13 P14 P15 P16 N16 N17 N18 R13 R14 Signal Name RSVD RSVD RSVD RSVD RSVD RSVD RSVD VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS P_DATA15/OE_CLK2 P_DATA14/OE_CLK1 P_DATA13/OE_CLK0 VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS Ball No. E24 D24 D25 D26 C26 D27 C27 N12 N13 K17 K18 M10 N10 M20 N20 U10 V10 U20 V20 Y12 Y13 Y17 Y18 K12 K13 M16 M17 M18 F16 F17
Data Sheet
Signal Name BIST_DONE/TSTOUT[15] BIST_IN_PRC/TST0UT[14 ] MCT_ERR/TSTOUT[13] FCB_ERR/TSTOUT[12] CHECKSUM_OK/TSTOUT [11] INIT_START/TSTOUT[10] INIT_DONE/TSTOUT[9] VSS VSS VDD VDD VDD VDD VDD VDD VDD VDD VDD VDD VDD VDD VDD VDD VDD VDD VSS VSS VSS VCC VCC
27
Zarlink Semiconductor Inc.
ZL50416
Ball No. F1 D1 D22 E23 E27 N28 N27 F2 G2 B22 A22 C23 B23 A23 C24 D23 T27 F27 C20 B20 A20 C21 E20 B25 Signal Name VDDA VSSA SCANCOL SCANLINK SCANMODE NC NC RESIN# RESETOUT# P_DATA5/MIRROR5 P_DATA4/MIRROR4 P_DATA3/MIRROR3 P_DATA2/MIRROR2 P_DATA1/MIRROR1 P_DATA0/MIRROR0 SCANCLK RSVD RSVD P_DATA12/L_CLK2 P_DATA11/L_CLK1 P_DATA10/L_CLK0 P_DATA9/P_D P_DATA8 P_INT Ball No. R15 R16 R17 R18 T12 T13 T14 T15 T16 T17 T18 U12 U13 U14 U15 U16 U17 M12 M13 M14 M15 P17 P18 R12 VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS Signal Name Ball No. N6 P6 R6 T6 U6 N24 P24 R24 T24 U24 AD13 AD14 AD15 AD16 AD17 F13 F14 F15 VCC VCC VCC VCC VCC VCC VCC VCC VCC VCC VCC VCC VCC VCC VCC VCC VCC VCC
Data Sheet
Signal Name
28
Zarlink Semiconductor Inc.
ZL50416
1.4 Signal Mapping and Internal Pull Up/Down Configuration
Data Sheet
The ZL50416 Fast Ethernet ports (0-15) support 2 interface options: RMII & GPSI. The table below summarizes the interface signals required for each interface and how they relate back to the Pin Symbol name shown in "Ball - Signal Descriptions" on page 14.
Notes: I - Input O - Output NC - No Connect
Fast Ethernet Ports Pin Symbol
Mn_RXD0 Mn_RXD1 Mn_CRS_DV Mn_TXD0 Mn_TXD1 Mn_TXEN M_CLK SCANCLK SCANLINK SCANCOL
RMII Mode
(Bootstrap Mn_TXEN='1')
GPSI Mode
(Bootstrap Mn_TXEN='0')
Mn_RXD0 (I) Mn_RXD1 (I) Mn_CRS_DV (I) Mn_TXD0 (O) Mn_TXD1 (O) Mn_TXEN (O) M_CLK (I) NC NC NC
Mn_RXD (I) Mn_RXCLK (I) Mn_CRS (I) Mn_TXD (O) Mn_TXCLK (I) Mn_TXEN (O) M_CLK (I) SCANCLK (O) SCANLINK (IO) SCANCOL (IO)
Table 1 - Fast Ethernet Ports Signal Mapping In Different Operation Mode
29
Zarlink Semiconductor Inc.
ZL50416
Data Sheet
The ZL50416 CPU access support 3 interface options: 8 or 16-bit parallel and unmanaged serial (with optional EEPROM). The table below summarizes the interface signals required for each interface, and how they relate back to the Pin Symbol name shown in "Ball - Signal Descriptions" on page 14.
Notes: I - Input O - Output U - Pull-up D - Pull-down NC - No Connect
Management Interface Pin Symbol
16-bit CPU
(Bootstrap TSTOUT6='1' and TSTOUT14='0')
8-bit CPU
(Bootstrap TSTOUT6='0' and TSTOUT14='0')
Serial
(Bootstrap TSTOUT14='1' and TSTOUT8='1')
Serial, I2C
(Bootstrap TSTOUT14='1' and TSTOUT8='0')
P_A[0] P_A[1] P_A[2] P_WE# P_RD# P_CS# P_INT# P_DATA0 P_DATA1 P_DATA2 P_DATA3 P_DATA4 P_DATA5 P_DATA6 P_DATA7 P_DATA8 P_DATA9 P_DATA10 P_DATA11 P_DATA12 P_DATA13 P_DATA14 P_DATA15
P_A[0] (I) P_A[1] (I) P_A[2] (I) P_WE# (I) P_RD# (I) P_CS# (I) P_INT# (O) P_DATA0 (IOU) P_DATA1 (IOU) P_DATA2 (IOU) P_DATA3 (IOU) P_DATA4 (IOU) P_DATA5 (IOU) P_DATA6 (IOD) P_DATA7 (IOD) P_DATA8 (IOU) P_DATA9 (IOU) P_DATA10 (IOU) P_DATA11 (IOU) P_DATA12 (IOU) P_DATA13 (IOU) P_DATA14 (IOU) P_DATA15 (IOU)
P_A[0] (I) P_A[1] (I) P_A[2] (I) P_WE# (I) P_RD# (I) P_CS# (I) P_INT# (O) P_DATA0 (IOU) P_DATA1 (IOU) P_DATA2 (IOU) P_DATA3 (IOU) P_DATA4 (IOU) P_DATA5 (IOU) P_DATA6 (IOD) P_DATA7 (IOD) NC (U) NC (U) NC (U) NC (U) NC (U) NC (U) NC (U) NC (U)
NC NC NC STROBE (IU) DATAOUT (O) DATAIN (IU) NC (O) NC (U) NC (U) NC (U) NC (U) NC (U) NC (U) NC (D) NC (D) NC (U) NC (U) NC (U) NC (U) NC (U) NC (U) NC (U) NC (U)
SDA (IO) SCL (O) NC STROBE (IU) DATAOUT (O) DATAIN (IU) NC (O) NC (U) NC (U) NC (U) NC (U) NC (U) NC (U) NC (D) NC (D) NC (U) NC (U) NC (U) NC (U) NC (U) NC (U) NC (U) NC (U)
Table 2 - CPU Interface Signal Mapping in Different Operation Mode
30
Zarlink Semiconductor Inc.
ZL50416 2.0
2.1
Data Sheet
Block Functionality
Frame Data Buffer (FDB) Interfaces
The FDB interface supports pipelined synchronous burst SRAM (SBRAM) memory at 100 MHz. To ensure a nonblocking switch, one memory domain with a 64-bit wide memory bus is required. At 100 MHz, the aggregate memory bandwidth is 6.4 Gbps which is enough to support 16 10/100 M ports at full wire speed switching. The Switching Database is also located in the external SRAM; it is used for storing MAC addresses and their physical port number.
2.2 2.2.1
MAC Modules RMII MAC Module (RMAC)
The 10/100 M Media Access Control (RMAC) module provides the necessary buffers and control interface between the Frame Engine (FE) and the external physical device (PHY). The ZL50416 RMAC implements two interfaces, RMII or GPSI (7WS) (only for 10 M), and fully meets the IEEE 802.3 specification. It is able to operate in either Half or Full Duplex mode with a back pressure/flow control mechanism. In addition, it will automatically retransmit upon collision for up to 16 total transmissions. The PHY addresses for 16 RMACs are from 08h to 17h. These sixteen ports are denoted as ports 0 to 15.
2.2.1.1
GPSI Interface
The 10/100 M RMII ethernet port can function in GPSI (7WS) mode when the corresponding TXEN pin is strapped low with a 1 K pull down resistor. In this mode, the TXD[0], TXD[1], RXD[0] and RXD[1] serve as TX data, TX clock, RX data and RX clock respectively. The link status and collision from the PHY are multiplexed and shifted into the switch device through external glue logic. The duplex of the port can be controlled by programming the ECR register. The GPSI interface can be operated in port based VLAN mode only.
31
Zarlink Semiconductor Inc.
ZL50416
Data Sheet
CRS_DV RXD[0] RXD[1] TXD[1] TXD[0] TXEN
crs rxd rx_clk tx_clk txd txen Port 0 Ethernet PHY link0 col0
link1 Switch col1 link2 col2
link23 col23 Port 23 Ethernet PHY
SCANLINK
SCANCOL
SCANCLK
Link Serializer (CPLD)
Collision Serializer (CPLD)
Figure 2 - GPSI (7WS) Mode Connection Diagram
32
Zarlink Semiconductor Inc.
ZL50416
2.2.1.2 SCANLINK and SCANCOL interface
Data Sheet
An external CPLD logic is required to take the link signals and collision signals from the GPSI PHYs and shift them into the switch device. The switch device will drive out a signature to indicate the start of the sequence. After that, the CPLD should shift in the link and collision status of the PHYS as shown in the figure. The extra link status indicates the polarity of the link signal. One indicates the polarity of the link signal is active high.
scan_clk
scan_link/ scan_col
Drived by device Drived by VTX260x
25 cycles for link/ 24 cycles for col
Drived by CPLD Drived by CPLD
Total 32 cycles period Total 32 cycles period
Figure 3 - SCANLINK and SCANCOL Status Diagram
2.2.2
CPU MAC Module (CMAC)
The CPU Media Access Control (CMAC) module provides the necessary buffers and control interface between the Frame Engine (FE) and the external CPU device. It support a register access mechanism via the 8/16-bit CPU interface (bootstrap pin TSTOUT6 makes the selection). The CMAC port is denoted as port 24.
2.2.3
PHY Addresses
The table below provides an overview of the PHY addresses required for each port in order for the MDIO autonegotiation to work between the ZL50416 MAC and the PHY device. If a different PHY address is used, then the port must be manually brought up and the PHY will need to be polled for link status via the MIIC/D registers. MAC Port RMAC Port 0 RMAC Port 1 ... RMAC Port 15 CMAC Port PHY Address 0x08 0x09 ... 0x17 N/A Table 3 - PHY Addresses
2.3
Management Module
The CPU can send a control frame to access or configure the internal databases within the ZL50416 device. The Management Module decodes the control frame and executes the functions requested by the CPU. The management module then sends a response or acknowledgment back to the CPU. This Module is only active in managed mode. In unmanaged mode, no control frame is accepted by the device.
33
Zarlink Semiconductor Inc.
ZL50416
2.4 Frame Engine
Data Sheet
The main function of the frame engine is to forward a frame to its proper destination port or ports. When a frame arrives, the frame engine parses the frame header (64 bytes) and formulates a switching request which is sent to the search engine to resolve the destination port. The arriving frame is moved to the FDB. After receiving a switch response from the search engine, the frame engine performs transmission scheduling based on the frame's priority. The frame engine forwards the frame to the MAC module when the frame is ready to be sent.
2.5
Search Engine
The search engine resolves the frame's destination port or ports by searching the appropriate ZL50416 databases. To achieve its objective, the search engine may use the destination MAC address, IP multicast address (IP multicast packet), and VLAN fields in the packet header. The search engine is also responsible for MAC and VLAN learning, assignment of transmission priority based on IEEE 802.1p or IP TOS/DS fields, and port trunking functions.
2.6
LED Interface
The LED interface provides a serial interface for carrying 16 port status signals. A serial output channel provides port status information from the ZL50416 chips. It requires three additional pins. LED_CLK at 12.5 MHz LED_SYN a sync pulse that defines the boundary between status frames LED_DATA a continuous serial stream of data for all status LEDs that repeats once every frame time A low cost external device (44 pin PAL) is used to decode the serial data and to drive an LED array for display. This device can be customized for different needs.
2.6.1
Port Status
In the ZL50416, each port has 8 status indicators, each represented by a single bit. The 8 LED status indicators are: Bit 0: Flow control Bit 1: Transmit data Bit 2: Receive data Bit 3: Activity (where activity includes either transmission or reception of data) Bit 4: Link up Bit 5: Speed (1= 100 Mb/s; 0= 10 Mb/s) Bit 6: Full-duplex Bit 7: Collision Eight clocks are required to cycle through the eight status bits for each port. When the LED_SYN pulse is asserted, the LED interface will present 256 LED clock cycles with the clock cycles providing information for the following ports. Port 0 (10/100M): cycles #0 to cycle #7 Port 1 (10/100M): cycles#8 to cycle #15 ... Port 14 (10/100M): cycle #112 to cycle #119
34
Zarlink Semiconductor Inc.
ZL50416
Port 15 (10/100M): cycle #120 to cycle #127 RSVD: cycle #128 to cycle #207 Byte 26 (additional status): cycle #208 to cycle #215 Byte 27 (additional status): cycle #216 to cycle #223 Cycles #224 to 256 present data with a value of zero.
Data Sheet
The first two bits of byte 26 are reserved while the remainder of byte 26 and byte 27 provides bist status. 26[0]: RSVD 26[1]: RSVD 26[2]: initialization done 26[3]: initialization start 26[4]: checksum ok 26[5]: link_init_complete 26[6]: bist_fail 26[7]: ram_error 27[0]: bist_in_process 27[1]: bist_done
2.6.2
LED Interface Timing Diagram
The signal from the ZL50416 to the LED decoder is shown in Figure 7.
Figure 4 - Timing Diagram of LED Interface
2.7
Internal Memory
Several internal tables are required and are described as follows: * * * Frame Control Block (FCB) - Each FCB entry contains the control information of the associated frame stored in the FDB, e.g., frame size, read/write pointer, transmission priority, etc. Network Management (NM) Database - The NM database contains the information in the statistics counters and MIB. MAC address Control Table (MCT) Link Table - The MCT Link Table stores the linked list of MCT entries that have collisions in the external MAC Table.
Note that the external MAC table is located in the external SRAM Memory.
2.8
Timeout Reset Monitor
The ZL50416 supports a state machine monitoring block which can trigger a reset if any state machine is determined to be stuck in a non-idle state for more than 5 seconds. This feature is enabled via a bootstrap pin (TSTOUT11).
35
Zarlink Semiconductor Inc.
ZL50416 3.0
3.1
Data Sheet
System Configuration (Stand-alone and Stacking)
Management and Configuration
Two modes are supported in the ZL50416: managed and unmanaged. In managed mode, the ZL50416 uses an 8or 16-bit CPU interface very similar to the Industry Standard Architecture (ISA) specification. In unmanaged mode, the ZL50416 has no CPU but can be configured by EEPROM using an I2C interface at bootup, or via a synchronous serial interface otherwise.
3.2
Managed Mode
In managed mode, the ZL50416 uses an 8- or 16-bit CPU interface very similar to the ISA bus. The ZL50416 CPU interface provides for easy and effective management of the switching system. Figure 5 provides an overview of the CPU interface.
INDEX REG 1 (Addr = 001)
INDEX REG 0 (Addr = 000)
CONFIG DATA REG (Addr = 010) 8 bit internal data bus
FRAME DATA REG (Addr = 011) 8/16 bit internal data bus 8/16 bit internal data bus
CONTROL BLOCK REG
16 bit internal address bus
INTERNAL CONFIGURE REGISTERS
CPU FRAME RECEIVE FIFO
CPU FRAME TRANSMIT FIFO
CONTROL COMMAND FRAME RECEIVE FIFO
CONTROL COMMAND FRAME TRANSMIT FIFO 1 AND 2
SYNOCHRONOUS SERIAL INTERFACE
Figure 5 - Overview of the CPU Interface
3.2.1 3.2.1.1
Register Configuration, Frame Transmission, and Frame Reception Register Configuration
The ZL50416 has many programmable parameters, covering such functions as QoS weights, VLAN control and port mirroring setup. In managed mode, the CPU interface provides an easy way of configuring these parameters. The parameters are contained in 8-bit configuration registers. The ZL50416 allows indirect access to these registers, as follows: * If operating in 8 bits-interface mode, two "index" registers (addresses 000 and 001) need to be written to indicate the desired 8-bit register address. In 16-bit mode, only one register (address 000) needs to be written for the desired 16-bit register address.
36
Zarlink Semiconductor Inc.
ZL50416
* *
Data Sheet
To indirectly configure the register addressed by the two index registers, a "configure data" register (address 010) must be written with the desired 8-bit data. Similarly, to read the value in the register addressed by the two index registers, the "configure data" register can now simply be read.
In summary, access to the many internal registers is carried out simply by directly accessing only three registers - two registers to indicate the address of the desired parameter, and one register to read or write a value. Of course, because there is only one bus master, there can never be any conflict between reading and writing the configuration registers.
3.2.1.2
Rx/Tx of Standard Ethernet Frames
The CPU interface is also responsible for receiving and transmitting standard Ethernet frames to and from the CPU. To transmit a frame from the CPU: * * The CPU writes a "data frame" register (address 011) with the data it wants to transmit (minimum 64 bytes). After writing all the data, it then writes the frame size, destination port number and frame status. The ZL50416 forwards the Ethernet frame to the desired destination port, no longer distinguishing the fact that the frame originated from the CPU.
To receive a frame into the CPU: * * * The CPU receives an interrupt when an Ethernet frame is available to be received. Frame information arrives first in the data frame register. This includes source port number, frame size and VLAN tag. The actual data follows the frame information. The CPU uses the frame size information to read the frame out.
In summary, receiving and transmitting frames to and from the CPU is a simple process that uses one direct access register only.
3.2.1.3
Control Frames
In addition to standard Ethernet frames described in the preceding section, the CPU is also called upon to handle special "Control frames," generated by the ZL50416 and sent to the CPU. These proprietary frames are related to such tasks as statistics collection, MAC address learning and aging etc. All Control frames are up to 40 bytes long. Transmitting and receiving these frames is similar to transmitting and receiving Ethernet frames, except that the register accessed is the "Control frame data" register (address 111). Specifically, there are eight types of control frames generated by the CPU and sent to the ZL50416: * * * * * * * * Memory read request Memory write request Learn MAC address Delete MAC address Search MAC address Learn IP Multicast address Delete IP Multicast address Search IP Multicast address
Note: Memory read and write requests by the CPU may include VLAN table, spanning tree, statistic counters and similar updates.
37
Zarlink Semiconductor Inc.
ZL50416
In addition, there are nine types of Control frames generated by the ZL50416 and sent to the CPU: * * * * * * * * * Interrupt CPU when statistics counter rolls over Response to memory read request from CPU Learn MAC address Delete MAC address Delete IP Multicast address New VLAN port Age out VLAN port Response to search MAC address request from CPU Response to search IP Multicast address request from CPU
Data Sheet
The format of the Control Frame is described in the processor interface application note.
3.3
Unmanaged Mode
In unmanaged mode, the ZL50416 can be configured by EEPROM (24C02 or compatible) via an I2C interface at boot time, or via a synchronous serial interface during operation.
3.3.1
I2C Interface
The IC interface serves the function of configuring the ZL50416 at boot time. The master is the ZL50416, and the slave is the EEPROM memory. The I2C interface uses two bus lines, a serial data line (SDA) and a serial clock line (SCL). The SCL line carries the control signals that facilitate the transfer of information from EEPROM to the switch. Data transfer is 8-bit serial and bidirectional at 50 Kbps. Data transfer is performed between master and slave IC using a request / acknowledgment style of protocol. The master IC generates the timing signals and terminates data transfer. Figure 3 depicts the data transfer format. The slave address is the memory address of the EEPROM. Refer to "Register Definition" on page 67 for IC address for each register.
START SLAVE ADDRESS R/W ACK DATA 1 (8 bits) ACK DATA 2 ACK DATA M ACK STOP
Figure 6 - Data Transfer Format for I2C Interface
3.3.1.1
Start Condition
Generated by the master (in our case, the ZL50416). The bus is considered to be busy after the Start condition is generated. The Start condition occurs if while the SCL line is High, there is a High-to-Low transition of the SDA line. Other than in the Start condition (and Stop condition), the data on the SDA line must be stable during the High period of SCL. The High or Low state of SDA can only change when SCL is Low. In addition, when the I2C bus is free, both lines are High.
3.3.1.2
Address
The first byte after the Start condition determines which slave the master will select. The slave in our case is the EEPROM. The first seven bits of the first data byte make up the slave address.
3.3.1.3
Data Direction
The eighth bit in the first byte after the Start condition determines the direction (R/W) of the message. A master transmitter sets this bit to W; a master receiver sets this bit to R.
38
Zarlink Semiconductor Inc.
ZL50416
3.3.1.4 Acknowledgment
Data Sheet
Like all clock pulses, the acknowledgment-related clock pulse is generated by the master. However, the transmitter releases the SDA line (High) during the acknowledgment clock pulse. Furthermore, the receiver must pull down the SDA line during the acknowledge pulse so that it remains stable Low during the High period of this clock pulse. An acknowledgment pulse follows every byte transfer. If a slave receiver does not acknowledge after any byte, then the master generates a Stop condition and aborts the transfer. If a master receiver does not acknowledge after any byte, then the slave transmitter must release the SDA line to let the master generate the Stop condition.
3.3.1.5
Data
After the first byte containing the address, all bytes that follow are data bytes. Each byte must be followed by an acknowledge bit. Data is transferred MSB first.
3.3.1.6
Stop Condition
Generated by the master. The bus is considered to be free after the Stop condition is generated. The Stop condition occurs if while the SCL line is High, there is a Low-to-High transition of the SDA line.
3.3.2
Synchronous Serial Interface
The synchronous serial interface (SSI) serves the function of configuring the ZL50416, not at boot time, but via a PC. The PC serves as master and the ZL50416 serves as slave. The protocol for the synchronous serial interface is nearly identical to the I2C protocol. The main difference is that there is no acknowledgment bit after each byte of data transferred. The unmanaged ZL50416 uses a synchronous serial interface to program the internal registers. To reduce the number of signals required, the register address, command and data are shifted in serially through the D0 pin. STROBE pin is used as the shift clock. AUTOFD pin is used as data return path. Each command consists of four parts. * * * * START pulse Register Address Read or Write command Data to be written or read back
Any command can be aborted in the middle by sending a ABORT pulse to the ZL50416. A START command is detected when D0 is sampled high when STROBE rise and D0 is sampled low when STROBE fall. An ABORT command is detected when D0 is sampled low when STROBE rise and D0 is sampled high when STROBE fall. All registers in ZL50416 can be modified through this synchronous serial interface.
39
Zarlink Semiconductor Inc.
ZL50416
3.3.2.1 Write Command
Data Sheet
STROBE2 extraExtra clocks after last 2 clock cycles after last transfer transfer
D0
A0 A1 A2 A0 A1 A2 ...
START
A9 A10 A11 W A9 A10 A11
D0 D1 D2 D3 D4 D5 D6 D7 DATA
ADDRESS
COMMAND
3.3.2.2
Read Command
STROBE-
D0
A0 A1 A2 A0 A1 A2 START
A10 A11 A9 ... A9 A10 A11
R DATA
ADDRESS
COMMAND
AUTOFD-
D0 D1 D2 D3 D4 D5 D6 D7
4.0
4.1
Data Forwarding Protocol
Unicast Data Frame Forwarding
When a frame arrives, it is assigned a handle in memory by the Frame Control Buffer Manager (FCB Manager). An FCB handle will always be available because of advance buffer reservations. The memory (SRAM) interface consists of one 64-bit bus, connected to one SRAM bank, A. The Receive DMA (RxDMA) is responsible for multiplexing the data and the address. On a port's "turn," the RxDMA will move 8 bytes (or up to the end-of-frame) from the port's associated RxFIFO into memory (Frame Data Buffer, or FDB). Once an entire frame has been moved to the FDB, and a good end-of-frame (EOF) has been received, the Rx interface makes a switch request. The RxDMA arbitrates among multiple switch requests. The switch request consists of the first 64 bytes of a frame, containing among other things, the source and destination MAC addresses of the frame. The search engine places a switch response in the switch response queue of the frame engine when done. Among other information, the search engine will have resolved the destination port of the frame and will have determined that the frame is unicast. After processing the switch response, the Transmission Queue Manager (TxQ manager) of the frame engine is responsible for notifying the destination port that it has a frame to forward to it. But first, the TxQ manager has to decide whether or not to drop the frame, based on global FDB reservations and usage, as well as TxQ occupancy at the destination. If the frame is not dropped, then the TxQ manager links the frame's FCB to the correct per-portper-class TxQ. Unicast TxQ's are linked lists of transmission jobs, represented by their associated frames' FCB's. There is one linked list for each transmission class for each port. There are 4 transmission classes for each of the 16 10/100 M ports - a total of 64 unicast queues. The TxQ manager is responsible for scheduling transmission among the queues representing different classes for a port. When the port control module determines that there is room in the MAC Transmission FIFO (TxFIFO) for
40
Zarlink Semiconductor Inc.
ZL50416
Data Sheet
another frame, it requests the handle of a new frame from the TxQ manager. The TxQ manager chooses among the head-of-line (HOL) frames from the per-class queues for that port using a Zarlink Semiconductor scheduling algorithm. The Transmission DMA (TxDMA) is responsible for multiplexing the data and the address. On a port's turn, the TxDMA will move 8 bytes (or up to the EOF) from memory into the port's associated TxFIFO. After reading the EOF, the port control requests a FCB release for that frame. The TxDMA arbitrates among multiple buffer release requests. The frame is transmitted from the TxFIFO to the line.
4.2
Multicast Data Frame Forwarding
After receiving the switch response, the TxQ manager has to make the dropping decision. A global decision to drop can be made, based on global FDB utilization and reservations. If so, then the FCB is released and the frame is dropped. In addition, a selective decision to drop can be made, based on the TxQ occupancy at some subset of the multicast packet's destinations. If so, then the frame is dropped at some destinations but not others and the FCB is not released. If the frame is not dropped at a particular destination port, then the TxQ manager formats an entry in the multicast queue for that port and class. Multicast queues are physical queues (unlike the linked lists for unicast frames). There are 2 multicast queues for each of the 16 10/100 M ports. The queue with higher priority has room for 32 entries and the queue with lower priority has room for 64 entries. For the 10/100 M ports to map the 8 transmit priorities into 2 multicast queues, the 2 LSB are discarded. During scheduling, the TxQ manager treats the unicast queue and the multicast queue of the same class as one logical queue. The older head of line of the two queues is forwarded first. The port control requests a FCB release only after the EOF for the multicast frame has been read by all ports to which the frame is destined.
4.3
Frame Forwarding To and From CPU
Frame forwarding from the CPU port to a regular transmission port is nearly the same as forwarding between transmission ports. The only difference is that the physical destination port must be indicated in addition to the destination MAC address. Frame forwarding to the CPU port is nearly the same as forwarding to a regular transmission port. The only difference is in frame scheduling. Instead of using the patent-pending Zarlink Semiconductor scheduling algorithms, scheduling for the CPU port is simply based on strict priority. That is, a frame in a high priority queue will always be transmitted before a frame in a lower priority queue. There are four output queues to the CPU and one receive queue.
41
Zarlink Semiconductor Inc.
ZL50416 5.0
5.1
Data Sheet
Memory Interface
Overview
The ZL50416 provides one 64-bit wide SRAM bank, SRAM Bank A. Each DMA can read and write from bank A. The following figure provides an overview of the ZL50416 SRAM banks.
SRAM
SRAM
TX DMA 0-7
TX DMA 8-15
TX DMA 16-23
RX DMA 0-7
RX DMA 8-15
RX DMA 16-23
Figure 7 - SRAM Interface Block Diagram (DMAs for 10/100 Ports Only) Because the bus for the bank is 64 bits wide, frames are broken into 8-byte granules, written to and read from memory.
5.2
Memory Requirements
To support 64 K MAC address, 2 MB memory is required. When VLAN support is enabled, 512 entries of the MAC address table are used for storing the VLAN ID in the VLAN Index Mapping Table. Up to 1K Ethernet frame buffers are supported and they will use 1.5 MB of memory. Each frame uses 1536 bytes. The maximum system memory requirement is 2 MB. If less memory is desired, the configuration can scale down. Tagged-based VLAN Disable Enable Disable Enable Max. Frame Buffers 0.5 K 0.5 K 1K 1K
Bank A 1M 1M 2M 2M
Max MAC Address 32 K 31.5 K 64 K 63.5 K
42
Zarlink Semiconductor Inc.
ZL50416
Data Sheet
Figure 8 - Memory Configuration
5.3
Memory Configurations
The ZL50416 supports pipelined SBRAM with 1 M and 2 M per bank configurations. For detail connection information, please reference the Memory Interface Application Note, MSAN-211. 1 M per bank (Bootstrap pin TSTOUT7 = open) Two 128 K x 32 SBRAM/bank
or or
SBRAM Configurations Single Layer (Bootstrap pin TSTOUT13 = open) Double Layer (Bootstrap pin TSTOUT13 = pulled down)
2 M per bank (Bootstrap pin TSTOUT7 = pulled down) Two 256 K x 32 SBRAM/bank One 256 K x 64 SBRAM/bank Four 128 K x 32 SBRAM/bank
or
Connections Connect 0E# and WE# Connect 0E0# and WE0# Connect 0E1# and WE1#
One 128 K x 64 SBRAM/bank NA
Two 128 K x 64 SBRAM/bank Table 4 - Supported Memory Configurations (SBRAM Mode) Table 5 - Options for Memory Configuration
43
Zarlink Semiconductor Inc.
ZL50416
Bank A (1 M One Layer)
Data LA_D[63:32]
Data Sheet
Bank B (1 M One Layer)
Data LB_D[63:32]
Data LA_D[31:0] SRAM Memory 128K 32 bits Memory 128K 32 bits
Data LB_D[31:0] SRAM Memory 128K 32 bits Memory 128K 32 bits
Address LA_A[19:3]
Address LB_A[19:3]
Bootstraps: TSTOUT7 = Open, TSTOUT13 = Open, TSTOUT4 = Open
Figure 9 - Memory Configuration For 1 M/bank, 1 Layer
Bank A (2 M Two Layers)
Data LA_D[63:32]
Bank B (2 M Two Layers)
Data LB_D[63:32]
Data LA_D[31:0] SRAM Memory 128 K 32 bits SRAM Memory 128 K 32 bits
Data LB_D[31:0] SRAM Memory 128 K 32 bits SRAM Memory 128 K 32 bits
SRAM Memory 128 K 32 bits
SRAM Memory 128 K 32 bits
SRAM Memory 128 K 32 bits
SRAM Memory 128 K 32 bits
Address LA_A[19:3]
Address LB_A[19:3]
Bootstraps: TSTOUT7 = Pull Down, TSTOUT13 = Pull Down, TSTOUT4 = Open
Figure 10 - Memory Configuration For 2 M/bank, 2 Layers
44
Zarlink Semiconductor Inc.
ZL50416
Bank A (2M One Layer)
Data LA_D[63:32]
Data Sheet
Bank B (2M One Layer)
Data LB_D[63:32]
Data LA_D[31:0] SRAM Memory 256K 32 bits Memory 256K 32 bits
Data LB_D[31:0] SRAM Memory 256K 32 bits Memory 256K 32 bits
Address LA_A[20:3]
Address LB_A[20:3]
Bootstraps: TSTOUT7 = Pull Down, TSTOUT13 = Open, TSTOUT4 = Open
Figure 11 - Memory Configuration For 2 M/bank, 1 Layer
6.0
6.1
Search Engine
Search Engine Overview
The ZL50416 search engine is optimized for high throughput searching, with enhanced features to support: * * * * * * * * * Up to 64 K MAC addresses Up to 255 tagged-based VLAN and IP Multicast groups 2 groups of port trunking Traffic classification into 4 transmission priorities and 2 drop precedence levels Packet filtering Security IP Multicast Flooding, Broadcast, Multicast Storm Control MAC address learning and aging
6.2
Basic Flow
Shortly after a frame enters the ZL50416 and is written to the Frame Data Buffer (FDB), the frame engine generates a Switch Request, which is sent to the search engine. The switch request consists of the first 64 bytes of the frame, which contain all the necessary information for the search engine to perform its task. When the search engine is done, it writes to the Switch Response Queue and the frame engine uses the information provided in that queue for scheduling and forwarding. In performing its task, the search engine extracts and compresses the useful information from the 64-byte switch request. Among the information extracted are the source and destination MAC addresses, the transmission and discard priorities, whether the frame is unicast or multicast, and VLAN ID. Requests are sent to the external SRAM to locate the associated entries in the external hash table. When all the information has been collected from external SRAM, the search engine has to compare the MAC address on the current entry with the MAC address for which it is searching. If it is not a match, the process is repeated on the internal MCT Table. All MCT entries other than the first of each linked list are maintained internal to
45
Zarlink Semiconductor Inc.
ZL50416
Data Sheet
the chip. If the desired MAC address is still not found, then the result is either learning (source MAC address unknown) or flooding (destination MAC address unknown). In addition, VLAN information is used to select the correct set of destination ports for the frame (for multicast), or to verify that the frame's destination port is associated with the VLAN (for unicast). If the destination MAC address belongs to a port trunk, then the trunk number is retrieved instead of the port number. But on which port of the trunk will the frame be transmitted? This is easily computed using a hash of the source and destination MAC addresses. When all the information is compiled, the switch response is generated, as stated earlier. The search engine also interacts with the CPU with regard to learning and aging.
6.3 6.3.1
Search, Learning, and Aging MAC Search
The search block performs source MAC address and destination MAC address (or destination IP address for IP multicast) searching. As we indicated earlier, if a match is not found, then the next entry in the linked list must be examined and so on until a match is found or the end of the list is reached. In tag-based VLAN mode, if the frame is unicast, and the destination port is not a member of the correct VLAN, then the frame is dropped; otherwise, the frame is forwarded. If the frame is multicast, this same table is used to indicate all the ports to which the frame will be forwarded. Moreover, if port trunking is enabled, this block selects the destination port (among those in the trunk group). In port-based VLAN mode, a bitmap is used to determine whether the frame should be forwarded to the outgoing port. The main difference in this mode is that the bitmap is not dynamic. Ports cannot enter and exit groups because of real-time learning made by a CPU. The MAC search block is also responsible for updating the source MAC address timestamp and the VLAN port association timestamp, used for aging.
6.3.2
Learning
The learning module learns new MAC addresses and performs port change operations on the MCT database. The goal of learning is to update this database as the networking environment changes over time. When CPU reporting is enabled, learning and port change will be performed when the CPU request queue has room, and a memory slot is available, and a "Learn MAC Address" message is sent to the CPU. When fast learning mode is enabled, learning and port change will be performed when memory slot is available and a latter "Learn MAC Address" message is sent to the CPU when CPU queue has room. When CPU reporting is disabled, learning and port change will be performed based on memory slot availability only. In tag based VLAN mode, if the source port is not a member of a classified VLAN a "New VLAN Port" message is sent to the CPU. The CPU can decide whether or not the source port can be added to the VLAN.
6.3.3
Aging
Aging time is controlled by register 400h and 401h. The aging module scans and ages MCT entries based on a programmable "age out" time interval. As we indicated earlier, the search module updates the source MAC address and VLAN port association timestamps for each frame it processes. When an entry is ready to be aged, the entry is removed from the table and a "Delete MAC Address" message is sent to inform the CPU.
46
Zarlink Semiconductor Inc.
ZL50416
Data Sheet
Supported MAC entry types are: dynamic, static, source filter, destination filter, IP multicast, source and destination filter and secure MAC address. Only dynamic entries can be aged; all others are static. The MAC entry type is stored in the "status" field of the MCT data structure.
6.4
MAC Address Filtering
The ZL50416's implementation of intelligent traffic switching provides filters for source and destination MAC addresses. This feature filters unnecessary traffic, thereby providing intelligent control over traffic flows and broadcast traffic. MAC address filtering allows the ZL50416 to block an incoming packet to an interface when it sees a specified MAC address in either the source address or destination address of the incoming packet. For example, if your network is congested because of high utilization from a MAC address you can filter all traffic transmitted from that address and restore network flow while you troubleshoot the problem.
6.5
Port- and Tagged-Based VLAN
The ZL50416 supports two models for determining and controlling how a packet gets assigned to a VLAN: portbased and tagged-based.
6.5.1
Port-Based VLAN
An administrator can use the PVMAP registers to configure the ZL50416 for port-based VLAN (See "Register Definition" on page 67.). For example, ports 1-3 might be assigned to the Marketing VLAN, ports 4-6 to the Engineering VLAN and ports 7-9 to the Administrative VLAN. The ZL50416 determines the VLAN membership of each packet by noting the port on which it arrives. From there, the ZL50416 determines which outgoing port(s) is/are eligible to transmit each packet or whether the packet should be discarded. Destination Port Numbers Bit Map Port Registers Register for Port #0 PVMAP00_0[7:0] to PVMAP00_3[2:0] Register for Port #1 PVMAP01_0[7:0] to PVMAP01_3[2:0] Register for Port #2 PVMAP02_0[7:0] to PVMAP02_3[2:0] ... Register for Port #26 PVMAP26_0[7:0] to PVMAP26_3[2:0] 0 0 0 0 26 0 0 0 ... 2 1 1 0 1 1 0 0 0 0 1 0
Table 6 - PVMAP Register For example, in the above table, a "1" denotes that an outgoing port is eligible to receive a packet from an incoming port. A 0 (zero) denotes that an outgoing port is not eligible to receive a packet from an incoming port. In this example: Data packets received at port #0 are eligible to be sent to outgoing ports 1 and 2. Data packets received at port #1 are eligible to be sent to outgoing ports 0 and 2. Data packets received at port #2 are NOT eligible to be sent to ports 0 and 1.
47
Zarlink Semiconductor Inc.
ZL50416
6.5.2 Tagged-Based VLAN
Data Sheet
The ZL50416 supports the IEEE 802.1Q specification for "tagging" frames. The specification defines a way to coordinate VLANs across multiple switches. In the specification, an additional 4-octet header (or "tag") is inserted in a frame after the source MAC address and before the frame type. 12 bits of the tag are used to define the VLAN ID. Packets are then switched through the network with each ZL50416 simply swapping the incoming tag for an appropriate forwarding tag rather than processing each packet's contents to determine the path. This approach minimizes the processing needed once the packet enters the tag-switched network. In addition, coordinating VLAN IDs across multiple switches enables VLANs to extend to multiple switches. Up to 255 VLANs are supported in the ZL50416. The 4 K VLANs specified in the IEEE 802.1Q are mapped to 255 VLAN indexes. The mapping is made within the VLAN index (VIX) mapping table. Based on the VIXn, the source and destination port membership is checked against the content in the VLAN Index Port Association Table. If the destination port is a member of the VLAN, the packet is forwarded; otherwise it is discarded. If the source port is not a member, a "New VLAN Port" message is sent to the CPU. A filter can be applied to discard the packet if the source port is not a member of the VLAN. For more information on VLANs and details of the VLAN tables, please refer to the IEEE 802.1Q VLAN Setup Application Note, ZLAN-06.
6.6
Quality of Service
Quality of Service (QoS) refers to the ability of a network to provide better service to selected network traffic over various technologies. Primary goals of QoS include dedicated bandwidth, controlled jitter and latency (required by some real-time and interactive traffic) and improved loss characteristics. Traditional Ethernet networks have had no prioritization of traffic. Without a protocol to prioritize or differentiate traffic, a service level known as "best effort" attempts to get all the packets to their intended destinations with minimum delay; however, there are no guarantees. In a congested network or when a low-performance switch/router is overloaded, "best effort" becomes unsuitable for delay-sensitive traffic and mission-critical data transmission. The advent of QoS for packet-based systems accommodates the integration of delay-sensitive video and multimedia traffic onto any existing Ethernet network. It also alleviates the congestion issues that have previously plagued such "best effort" networking systems. QoS provides Ethernet networks with the breakthrough technology to prioritize traffic and ensure that a certain transmission will have a guaranteed minimum amount of bandwidth. Extensive core QoS mechanisms are built into the ZL50416 architecture to ensure policy enforcement and buffering of the ingress port, as well as weighted fair-queue (WFQ) scheduling at the egress port. In the ZL50416, QoS-based policies sort traffic into a small number of classes and mark the packets accordingly. The QoS identifier provides specific treatment to traffic in different classes, so that different quality of service is provided to each class. Frame and packet scheduling and discarding policies are determined by the class to which the frames and packets belong. For example, the overall service given to frames and packets in the premium class will be better than that given to the standard class; the premium class is expected to experience lower loss rate or delay. The ZL50416 supports the following QoS techniques: * * * In a port-based setup, any station connected to the same physical port of the switch will have the same transmit priority. In a tag-based setup, a 3-bit field in the VLAN tag provides the priority of the packet. This priority can be mapped to different queues in the switch to provide QoS. In a TOS/DS-based set up, TOS stands for "Type of Service" that may include "minimize delay," "maximize throughput," or "maximize reliability." Network nodes may select routing paths or forwarding behaviours that are suitably engineered to satisfy the service request.
48
Zarlink Semiconductor Inc.
ZL50416
*
Data Sheet
In a logical port-based set up, a logical port provides the application information of the packet. Certain applications are more sensitive to delays than others; using logical ports to classify packets can help speed up delay sensitive applications, such as VoIP.
6.6.1
Priority Classification Rule
Figure 12 shows the ZL50416 priority classification rule.
Yes Fix Port Priority? No Use Default Port Settings No No TOS Precedence over VLAN? (FCR Register, Bit 7) No No VLAN Tag? IP Frame? Yes Use Default Port Settings
IP Yes
Yes
Yes No Use TOS
Use Logical Port Yes Use VLAN Priority Use Logical Port
Figure 12 - Priority Classification Rule
7.0
7.1
Frame Engine
Data Forwarding Summary
When a frame enters the device at the RxMAC, the RxDMA will move the data from the MAC RxFIFO to the FDB. Data is moved in 8-byte granules in conjunction with the scheme for the SRAM interface. A switch request is sent to the Search Engine. The Search Engine processes the switch request and a switch response is sent back to the Frame Engine. This response indicates whether the frame is unicast or multicast and its destination port or ports. A VLAN table lookup is performed as well. A Transmission Scheduling Request is sent in the form of a signal notifying the TxQ manager. Upon receiving a Transmission Scheduling Request, the device will format an entry in the appropriate Transmission Scheduling Queue (TxSch Q) or Queues. There are 4 TxSch Q for each 10/100 M port, one for each priority. Creation of a queue entry either involves linking a new job to the appropriate linked list if unicast or adding an entry to a physical queue if multicast. When the port is ready to accept the next frame, the TxQ manager will get the head-of-line (HOL) entry of one of the TxSch Qs, according to the transmission scheduling algorithm (to ensure per-class quality of service). The unicast linked list and the multicast queue for the same port-class pair are treated as one logical queue. The older HOL between the two queues goes first. For 10/100 M ports multicast queue 0 is associated with unicast queue 0 and multicast queue 1 is associated with unicast queue 2. The TxDMA will pull frame data from the memory and forward it granule-by-granule to the MAC TxFIFO of the destination port.
49
Zarlink Semiconductor Inc.
ZL50416
7.2 Frame Engine Details
Data Sheet
This section briefly describes the functions of each of the modules of the ZL50416 frame engine.
7.2.1
FCB Manager
The FCB manager allocates FCB handles to incoming frames and releases FCB handles upon frame departure. The FCB manager is also responsible for enforcing buffer reservations and limits. In addition, the FCB manager is responsible for buffer aging and for linking unicast forwarding jobs to their correct TxSch Q. The buffer aging can be enabled or disabled by the bootstrap pin and the aging time is defined in register FCBAT.
7.2.2
Rx Interface
The Rx interface is mainly responsible for communicating with the RxMAC. It keeps track of the start and end of frame and frame status (good or bad). Upon receiving an end of frame that is good, the Rx interface makes a switch request.
7.2.3
RxDMA
The RxDMA arbitrates among switch requests from each Rx interface. It also buffers the first 64 bytes of each frame for use by the search engine when the switch request has been made.
7.2.4
TxQ Manager
First, the TxQ manager checks the per-class queue status and global reserved resource situation and using this information makes the frame dropping decision after receiving a switch response. If the decision is not to drop, the TxQ manager requests that the FCB manager link the unicast frame's FCB to the correct per-port-per-class TxQ. If multicast, the TxQ manager writes to the multicast queue for that port and class. The TxQ manager can also trigger source port flow control for the incoming frame's source if that port is flow control enabled. Second, the TxQ manager handles transmission scheduling; it schedules transmission among the queues representing different classes for a port. Once a frame has been scheduled, the TxQ manager reads the FCB information and writes to the correct port control module.
7.2.5
Port Control
The port control module calculates the SRAM read address for the frame currently being transmitted. It also writes start of frame information and an end of frame flag to the MAC TxFIFO. When transmission is done, the port control module requests that the buffer be released.
7.2.6
TxDMA
The TxDMA multiplexes data and address from port control and arbitrates among buffer release requests from the port control modules.
8.0
8.1
Quality of Service and Flow Control
Model
Quality of service is an all-encompassing term for which different people have different interpretations. In general, the approach to quality of service described here assumes that we do not know the offered traffic pattern. We also assume that the incoming traffic is not policed or shaped. Furthermore, we assume that the network manager knows his applications, such as voice, file transfer, or web browsing and their relative importance. The manager can then subdivide the applications into classes and set up a service contract with each. The contract may consist of bandwidth or latency assurances per class. Sometimes it may even reflect an estimate of the traffic mix offered to
50
Zarlink Semiconductor Inc.
ZL50416
Data Sheet
the switch. As an added bonus, although we do not assume anything about the arrival pattern, if the incoming traffic is policed or shaped we may be able to provide additional assurances about our switch's performance. Table 7 shows examples of QoS applications with three transmission priorities, but best effort (P0) traffic may form a fourth class with no bandwidth or latency assurances. Goals TotalAssured Bandwidth (user defined) 50 Mbps Low Drop Probability
(low-drop)
High Drop Probability (high-drop) Apps: training video. Latency: < 1 ms. Drop: No drop if P3 not oversubscribed; first P3 to drop otherwise. Apps: non-critical interactive apps. Latency: < 4-5 ms. Drop: No drop if P2 not oversubscribed; first P2 to drop otherwise. Apps: casual web browsing. Latency: < 16 ms desired, but not critical. Drop: No drop if P1 not oversubscribed; first to drop otherwise.
Highest transmission priority, P3
Apps: phone calls, circuit emulation. Latency: < 1 ms. Drop: No drop if P3 not oversubscribed. Apps: interactive apps, Web business. Latency: < 4-5 ms. Drop: No drop if P2 not oversubscribed. Apps: emails, file backups. Latency: < 16 ms desired, but not critical. Drop: No drop if P1 not oversubscribed.
Middle transmission priority, P2
37.5 Mbps
Low transmission priority, P1
12.5 Mbps
Total
100 Mbps Table 7 - Two-dimensional World Traffic
A class is capable of offering traffic that exceeds the contracted bandwidth. A well-behaved class offers traffic at a rate no greater than the agreed-upon rate. By contrast, a misbehaving class offers traffic that exceeds the agreedupon rate. A misbehaving class is formed from an aggregation of misbehaving microflows. To achieve high link utilization, a misbehaving class is allowed to use any idle bandwidth. However, such leniency must not degrade the quality of service (QoS) received by well-behaved classes. As Table 7 illustrates, the six traffic types may each have their own distinct properties and applications. As shown, classes may receive bandwidth assurances or latency bounds. In the table, P3, the highest transmission class, requires that all frames be transmitted within 1 ms, and receives 50% of the 100 Mbps of bandwidth at that port. Best-effort (P0) traffic forms a fourth class that only receives bandwidth when none of the other classes have any traffic to offer. It is also possible to add a fourth class that has strict priority over the other three; if this class has even one frame to transmit, then it goes first. In the ZL50416, each 10/100 M port will support four total classes. We will discuss the various modes of scheduling these classes in the next section. In addition, each transmission class has two subclasses, high-drop and low-drop. Well-behaved users should rarely lose packets. But poorly behaved users - users who send frames at too high a rate - will encounter frame loss and the first to be discarded will be high-drop. Of course, if this is insufficient to resolve the congestion, eventually some low-drop frames are dropped and then all frames in the worst case. Table 7 shows that different types of applications may be placed in different boxes in the traffic table. For example, casual web browsing fits into the category of high-loss, high-latency-tolerant traffic, whereas VoIP fits into the category of low-loss, low-latency traffic.
51
Zarlink Semiconductor Inc.
ZL50416
8.2 Four QoS Configurations
Data Sheet
There are four basic pieces to QoS scheduling in the ZL50416: strict priority (SP), delay bound, weighted fair queuing (WFQ), and best effort (BE). Using these four pieces, there are four different modes of operation as shown in the tables below. For 10/100 M ports, the following registers select these modes: QOSC24 [7:6]_CREDIT_C00 QOSC28 [7:6]_CREDIT_C10 QOSC32 [7:6]_CREDIT_C20 QOSC36 [7:6]_CREDIT_C30 P3
Op1 (default) Op2 Op3 Op4
P2
P1
P0 BE
Delay Bound SP SP WFQ Delay Bound WFQ
BE
Table 8 - Four QoS Configurations for a 10/100 M Port The default configuration for a 10/100 M port is three delay-bounded queues and one best-effort queue. The delay bounds per class are 0,8 ms for P3, 3.2 ms for P2, and 12.8 ms for P1. Best effort traffic is only served when there is no delay-bounded traffic to be served. We have a second configuration for a 10/100 M port in which there is one strict priority queue, two delay bounded queues and one best effort queue. The delay bounds per class are 3.2 ms for P2 and 12.8 ms for P1. If the user is to choose this configuration, it is important that P3 (SP) traffic be either policed or implicitly bounded (e.g., if the incoming P3 traffic is very light and predictably patterned). Strict priority traffic, if not admission-controlled at a prior stage to the ZL50416, can have an adverse effect on all other classes' performance. The third configuration for a 10/100 M port contains one strict priority queue and three queues receiving a bandwidth partition via WFQ. As in the second configuration, strict priority traffic needs to be carefully controlled. In the fourth configuration, all queues are served using a WFQ service discipline.
8.3
Delay Bound
In the absence of a sophisticated QoS server and signaling protocol, the ZL50416 may not know the mix of incoming traffic ahead of time. To cope with this uncertainty, our delay assurance algorithm dynamically adjusts its scheduling and dropping criteria, guided by the queue occupancies and the due dates of their head-of-line (HOL) frames. As a result, we assure latency bounds for all admitted frames with high confidence, even in the presence of system-wide congestion. Our algorithm identifies misbehaving classes and intelligently discards frames at no detriment to well-behaved classes. Our algorithm also differentiates between high-drop and low-drop traffic with a weighted random early drop (WRED) approach. Random early dropping prevents congestion by randomly dropping a percentage of high-drop frames even before the chip's buffers are completely full, while still largely sparing lowdrop frames. This allows high-drop frames to be discarded early, as a sacrifice for future low-drop frames. Finally, the delay bound algorithm also achieves bandwidth partitioning among classes.
8.4
Strict Priority and Best Effort
When strict priority is part of the scheduling algorithm, if a queue has even one frame to transmit, it goes first. Two of our four QoS configurations include strict priority queues. The goal is for strict priority classes to be used for IETF
52
Zarlink Semiconductor Inc.
ZL50416
Data Sheet
expedited forwarding (EF), where performance guarantees are required. As we have indicated, it is important that strict priority traffic be either policed or implicitly bounded, so as to keep from harming other traffic classes. When best effort is part of the scheduling algorithm, a queue only receives bandwidth when none of the other classes have any traffic to offer. Two of our four QoS configurations include best effort queues. The goal is for best effort classes to be used for non-essential traffic, because we provide no assurances about best effort performance. However, in a typical network setting, much best effort traffic will indeed be transmitted and with an adequate degree of expediency. Because we do not provide any delay assurances for best effort traffic, we do not enforce latency by dropping best effort traffic. Furthermore, because we assume that strict priority traffic is carefully controlled before entering the ZL50416, we do not enforce a fair bandwidth partition by dropping strict priority traffic. To summarize, dropping to enforce bandwidth or delay does not apply to strict priority or best effort queues. We only drop frames from best effort and strict priority queues when global buffer resources become scarce.
8.5
Weighted Fair Queuing
In some environments - for example, in an environment in which delay assurances are not required, but precise bandwidth partitioning on small time scales is essential, WFQ may be preferable to a delay-bounded scheduling discipline. The ZL50416 provides the user with a WFQ option with the understanding that delay assurances can not be provided if the incoming traffic pattern is uncontrolled. The user sets four WFQ "weights" such that all weights are whole numbers and sum to 64. This provides per-class bandwidth partitioning with error within 2%. In WFQ mode, though we do not assure frame latency, the ZL50416 still retains a set of dropping rules that helps to prevent congestion and trigger higher level protocol end-to-end flow control. As before, when strict priority is combined with WFQ, we do not have special dropping rules for the strict priority queues, because the input traffic pattern is assumed to be carefully controlled at a prior stage. However, we do indeed drop frames from SP queues for global buffer management purposes. In addition, queue P0 for a 10/100 M port are treated as best effort from a dropping perspective, though they still are assured a percentage of bandwidth from a WFQ scheduling perspective. What this means is that these particular queues are only affected by dropping when the global buffer count becomes low.
8.6
Rate Control
The ZL50416 provides a rate control function on its 10/100 M ports. This rate control function applies to the outgoing traffic aggregate on each 10/100 M port. It provides a way of reducing the outgoing average rate below full wire speed. Note that the rate control function does not shape or manipulate any particular traffic class. Furthermore, though the average rate of the port can be controlled with this function, the peak rate will still be full line rate. Two principal parameters are used to control the average rate for a 10/100 M port. A port's rate is controlled by allowing, on average, M bytes to be transmitted every N microseconds. Both of these values are programmable. The user can program the number of bytes in 8-byte increments and the time may be set in units of 10 ms. The value of M/N will, of course, equal the average data rate of the outgoing traffic aggregate on the given 10/100 M port. Although there are many (M,N) pairs that will provide the same average data rate performance, the smaller the time interval N, the "smoother" the output pattern will appear. In addition to controlling the average data rate on a 10/100 M port, the rate control function also manages the maximum burst size at wire speed. The maximum burst size can be considered the memory of the rate control mechanism; if the line has been idle for a long time, to what extent can the port "make up for lost time" by transmitting a large burst? This value is also programmable, measured in 8-byte increments. Example: Suppose that the user wants to restrict Fast Ethernet port P's average departure rate to 32 Mbps - 32% of line rate - when the average is taken over a period of 10 ms. In an interval of 10 ms, exactly 40000 bytes can be transmitted at an average rate of 32 Mbps.
53
Zarlink Semiconductor Inc.
ZL50416
Data Sheet
So how do we set the parameters? The rate control parameters are contained in an internal RAM block accessible through the CPU port (See Programming QoS Registers application note and Processor interface application note). The data format is shown below. 63:40 0 39:32 Time interval 31:16 Maximum burst size 15:0 Number of bytes
As we indicated earlier, the number of bytes is measured in 8-byte increments, so the 16-bit field "Number of bytes" should be set to 40000/8, or 5000. In addition, the time interval has to be indicated in units of 10 ms. Though we want the average data rate on port P to be 32 Mbps when measured over an interval of 10 ms, we can also adjust the maximum number of bytes that can be transmitted at full line rate in any single burst. Suppose we wish this limit to be 12 kilobytes. The number of bytes is measured in 8-byte increments, so the 16-bit field "Maximum burst size" is set to 12000/8, or 1500.
8.7
WRED Drop Threshold Management Support
To avoid congestion, the Weighted Random Early Detection (WRED) logic drops packets according to specified parameters. The following table summarizes the behavior of the WRED logic. In KB (kilobytes) Level 1 N 120 Level 2 N 140 Level 3 N 160 Table 9 - WRED Drop Thresholds Px is the total byte count, in the priority queue x. The WRED logic has three drop levels, depending on the value of N, which is based on the number of bytes in the priority queues. If delay bound scheduling is used, N equals P3*16+P2*4+P1. If using WFQ scheduling, N equals P3+P2+P1. Each drop level from one to three has defined high-drop and low-drop percentages, which indicate the minimum and maximum percentages of the data that can be discarded. The X, Y Z percent can be programmed by the register RDRC0, RDRC1. In Level 3, all packets are dropped if the bytes in each priority queue exceed the threshold. Parameters A, B, C are the byte count thresholds for each priority queue. They can be programmed by the QOS control register (refer to the register group 5). See Programming QoS Registers Application Note, ZLAN-05, for more information. P3 P2 P1 High Drop X% P3 AKB P2 BKB P1 CKB Y% 100% Low Drop 0% Z% 100%
8.8
Buffer Management
Because the number of FDB slots is a scarce resource and because we want to ensure that one misbehaving source port or class cannot harm the performance of a well-behaved source port or class, we introduce the concept of buffer management into the ZL50416. Our buffer management scheme is designed to divide the total buffer space into numerous reserved regions and one shared pool as shown in Figure 13 on page 55. As shown in the figure, the FDB pool is divided into several parts. A reserved region for temporary frames stores frames prior to receiving a switch response. Such a temporary region is necessary, because when the frame first enters the ZL50416, its destination port and class are as yet unknown, and so the decision to drop or not needs to be temporarily postponed. This ensures that every frame can be received first before subjecting them to the frame drop discipline after classifying.
54
Zarlink Semiconductor Inc.
ZL50416
Data Sheet
Six reserved sections, one for each of the first six priority classes, ensure a programmable number of FDB slots per class. The lowest two classes do not receive any buffer reservation. Furthermore, even for 10/100M ports, a frame is stored in the region of the FDB corresponding to its class. As we have indicated, the eight classes use only four transmission scheduling queues for 10/100 M ports, but as far as buffer usage is concerned there are still eight distinguishable classes. Another segment of the FDB reserves space for each of the ports -- 16 ports for Ethernet and one CPU port (port number 24). One parameter can be set for the source port reservation for 10/100 M ports and CPU port. These reserved regions make sure that no well-behaved source port can be blocked by another misbehaving source port. In addition, there is a shared pool, which can store any type of frame. The frame engine allocates the frames first in the six priority sections. When the priority section is full or the packet has priority 1 or 0, the frame is allocated in the shared poll. Once the shared poll is full the frames are allocated in the section reserved for the source port. The following registers define the size of each section of the Frame data Buffer: PR100- Port Reservation for 10/100 M and CPU Ports SFCB- Share FCB Size C2RS- Class 2 Reserve Size C3RS- Class 3 Reserve Size C4RS- Class 4 Reserve Size C5RS- Class 5 Reserve Size C6RS- Class 6 Reserve Size C7RS- Class 7 Reserve Size
temporary reservation
shared pool reservation per-class reservations
per-source reservations
Figure 13 - Buffer Partition Scheme Used to Implement Buffer Management
55
Zarlink Semiconductor Inc.
ZL50416
8.8.1 Dropping When Buffers Are Scarce
Data Sheet
Summarizing the two examples of local dropping discussed earlier in this chapter: * * If a queue is a delay-bounded queue, we have a multi-level WRED drop scheme designed to control delay and partition bandwidth in case of congestion. If a queue is a WFQ-scheduled queue, we have a multi-level WRED drop scheme designed to prevent congestion.
In addition to these reasons for dropping, we also drop frames when global buffer space becomes scarce. The function of buffer management is to make sure that such dropping causes as little blocking as possible.
8.9
Flow Control Basics
Because frame loss is unacceptable for some applications, the ZL50416 provides a flow control option. When flow control is enabled, scarcity of buffer space in the switch may trigger a flow control signal; this signal tells a source port that is sending a packet to this switch, to temporarily hold off. While flow control offers the clear benefit of no packet loss, it also introduces a problem for quality of service. When a source port receives an Ethernet flow control signal, all microflows originating at that port, well-behaved or not, are halted. A single packet destined for a congested output can block other packets destined for uncongested outputs. The resulting head-of-line blocking phenomenon means that quality of service cannot be assured with high confidence when flow control is enabled. In the ZL50416, each source port can independently have flow control enabled or disabled. For flow control enabled ports, by default all frames are treated as lowest priority during transmission scheduling. This is done so that those frames are not exposed to the WRED Dropping scheme. Frames from flow control enabled ports feed to only one queue at the destination, the queue of lowest priority. This means that if flow control is enabled for a given source port then we can guarantee that no packets originating from that port will be lost but at the possible expense of minimum bandwidth or maximum delay assurances. In addition, these "downgraded" frames may only use the shared pool or the per-source reserved pool in the FDB; frames from flow control enabled sources may not use reserved FDB slots for the highest six classes (P2-P7). The ZL50416 does provide a system-wide option of permitting normal QoS scheduling (and buffer use) for frames originating from flow control enabled ports. When this programmable option is active, it is possible that some packets may be dropped even though flow control is on. The reason is that intelligent packet dropping is a major component of the ZL50416's approach to ensuring bounded delay and minimum bandwidth for high priority flows.
8.9.1
Unicast Flow Control
For unicast frames, flow control is triggered by source port resource availability. Recall that the ZL50416's buffer management scheme allocates a reserved number of FDB slots for each source port. If a programmed number of a source port's reserved FDB slots have been used then flow control Xoff is triggered. Xon is triggered when a port is currently being flow controlled and all of that port's reserved FDB slots have been released. Note that the ZL50416's per-source-port FDB reservations assure that a source port that sends a single frame to a congested destination will not be flow controlled.
56
Zarlink Semiconductor Inc.
ZL50416
8.9.2 Multicast Flow Control
Data Sheet
In unmanaged mode, flow control for multicast frames is triggered by a global buffer counter. When the system exceeds a programmable threshold of multicast packets Xoff is triggered. Xon is triggered when the system returns below this threshold. In managed mode, per-VLAN flow control is used for multicast frames. In this case, flow control is triggered by congestion at the destination. How so? The ZL50416 checks each destination to which a multicast packet is headed. For each destination port, the occupancy of the lowest-priority transmission multicast queue (measured in number of frames) is compared against a programmable congestion threshold. If congestion is detected at even one of the packet's destinations then Xoff is triggered. In addition, each source port has a 26-bit port map recording which port or ports of the multicast frame's fanout were congested at the time Xoff was triggered. All ports are continuously monitored for congestion and a port is identified as uncongested when its queue occupancy falls below a fixed threshold. When all those ports that were originally marked as congested in the port map have become uncongested, then Xon is triggered and the 26-bit vector is reset to zero. The ZL50416 also provides the option of disabling VLAN multicast flow control. Note: If per-Port flow control is on, QoS performance will be affected.
8.10
Mapping to IETF DiffServ Classes
The mapping between priority classes discussed in this chapter and elsewhere is shown below. ZL50416 IETF P3 NM+EF P2 AF0 P1 AF1 P0 BE0
Table 10 - Mapping between ZL50416 and IETF DiffServ Classes for 10/100 M Ports As Table 10 illustrates, P3 is used for network management (NM) frames and for expedited forwarding service (EF). Classes P2 and P1 correspond to an assured forwarding (AF) group of size 2. Finally, P0 is for best effort (BE) class. Features of the ZL50416 that correspond to the requirements of their associated IETF classes are summarized in the table below. Network management (NM) and Expedited forwarding (EF) * * * * * Global buffer reservation for NM and EF Option of strict priority scheduling No dropping if admission controlled Programmable bandwidth partition, with option of WFQ service Option of delay-bounded service keeps delay under fixed levels even if not admission-controlled Random early discard, with programmable levels Global buffer reservation for each AF class
Assured forwarding (AF)
* *
57
Zarlink Semiconductor Inc.
ZL50416
Best effort (BE) * * *
Data Sheet
Service only when other queues are idle means that QoS not adversely affected Random early discard, with programmable levels Traffic from flow control enabled ports automatically classified as BE
Table 11 - ZL50416 Features Enabling IETF DiffServ Standards
9.0
9.1
Port Trunking
Features and Restrictions
A port group (i.e., trunk) can include up to 4 physical ports but when using stack all of the ports in a group must be in the same ZL50416. Load distribution among the ports in a trunk for unicast is performed using hashing based on source MAC address and destination MAC address. Two other options include source MAC address only and destination MAC address only. Load distribution for multicast is performed similarly. If a VLAN includes any of the ports in a trunk group, all the ports in that trunk group should be in the same VLAN member map. The ZL50416 also provides a safe fail-over mode for port trunking automatically. If one of the ports in the trunking group goes down, the ZL50416 will automatically redistribute the traffic over to the remaining ports in the trunk in unmanaged mode. In managed mode, the software can perform similar tasks.
9.2
Unicast Packet Forwarding
The search engine finds the destination MCT entry, and if the status field says that the destination port found belongs to a trunk, then the group number is retrieved instead of the port number. In addition, if the source address belongs to a trunk then the source port's trunk membership register is checked. A hash key, based on some combination of the source and destination MAC addresses for the current packet selects the appropriate forwarding port as specified in the Trunk_Hash registers.
9.3
Multicast Packet Forwarding
For multicast packet forwarding, the device must determine the proper set of ports from which to transmit the packet based on the VLAN index and hash key. Two functions are required in order to distribute multicast packets to the appropriate destination ports in a port trunking environment. * * Determining one forwarding port per group. For multicast packets, all but one port per group, the forwarding port must be excluded. Preventing the multicast packet from looping back to the source trunk.
The search engine needs to prevent a multicast packet from sending to a port that is in the same trunk group with the source port. This is because when we select the primary forwarding port for each group, we do not take the source port into account. To prevent this, we simply apply one additional filter so as to block that forwarding port for this multicast packet.
58
Zarlink Semiconductor Inc.
ZL50416
9.4 Unmanaged Trunking
Data Sheet
In unmanaged mode, 2 trunk groups are supported. Groups 0 and 1 can trunk up to 4 10/100 M ports. The supported combinations are shown in the following table. Group 0 Port 0 Port 1 Port 2 Port 3
Select via trunk0_mode register Group 1 Port 4 Port 5 Port 6 Port 7
Select via trunk1_mode register In unmanaged mode, the trunks are individually enabled/disabled by controlling pin TRUNK0,1.
10.0
10.1
Port Mirroring
Port Mirroring Features
The received or transmitted data of any 10/100 M port in the ZL50416 chip can be "mirrored" to any other port. We support two such mirrored source-destination pairs. A mirror port can not also serve as a data port. Please refer to the Port Mirroring Application Note, MSAN-210, for further details.
10.2
Setting Registers for Port Mirroring
MIRROR1_SRC: Sets the source port for the first port mirroring pair. Bits [4:0] select the source port to be mirrored. An illegal port number is used to disable mirroring (which is the default setting). Bit [5] is used to select between ingress (Rx) or egress (Tx) data. MIRROR1_DEST: Sets the destination port for the first port mirroring pair. Bits [4:0] select the destination port to be mirrored. The default is port 23. MIRROR2_SRC: Sets the source port for the second port mirroring pair. Bits [4:0] select the source port to be mirrored. An illegal port number is used to disable mirroring (which is the default setting). Bit [5] is used to select between ingress (Rx) or egress (Tx) data. MIRROR2_DEST: Sets the destination port for the second port mirroring pair. Bits [4:0] select the destination port to be mirrored. The default is port 0.
59
Zarlink Semiconductor Inc.
ZL50416 11.0
11.1
Data Sheet
Hardware Statistics Counter
Hardware Statistics Counters List
ZL50416 hardware provides a full set of statistics counters for each Ethernet port. The CPU accesses these counters through the CPU interface. All hardware counters are rollover counters. When a counter rolls over the CPU is interrupted so that long-term statistics may be kept. The MAC detects all statistics except for the delay exceed discard counter (detected by buffer manager) and the filtering counter (detected by queue manager). The following is the wrapped signal sent to the CPU through the command block.
31 30 2 6 2 5 0
Status Wrapped Signal
B[0] B[1] B[2] B[3] B[4] B[5] B[6] B[7] B[8] B9] B[10] B[11] B[12] B[13] B[14] B[15] B[16] B[17] B[18] B[19] B[20] B[21] B[22] B[23]
0-d 1-L 1-U 2-I 2-u 3-d 4-d 5-d 6-L 6-U 7-l 7-u 8-L 8-U 9-L 9-U A-l A-u B-l B-u C-l C-U1 C-U D-l
Bytes Sent (D) Unicast Frame Sent Frame Send Fail Flow Control Frames Sent Non-Unicast Frames Sent Bytes Received (Good and Bad) (D) Frames Received (Good and Bad) (D) Total Bytes Received (D) Total Frames Received Flow Control Frames Received Multicast Frames Received Broadcast Frames Received Frames with Length of 64 Bytes Jabber Frames Frames with Length Between 65-127 Bytes Oversize Frames Frames with Length Between 128-255 Bytes Frames with Length Between 256-511 Bytes Frames with Length Between 512-1023 Bytes Frames with Length Between 1024-1528 Bytes Fragments Alignment Error Undersize Frames CRC
60
Zarlink Semiconductor Inc.
ZL50416
B[24] B[25] B[26] B[27] B[28] B[29] B[30] B[31] Notation: X-Y X: Y: Address in the contain memory Size and bits for the counter D-u E-l E-u F-l F-U1 F-U Short Event Collision Drop Filtering Counter Delay Exceed Discard Counter Late Collision Link Status Change Current link status
Data Sheet
d: L: U:
D Word counter 24 bits counter bit[23:0] 8 bits counter bit[31:24]
U1: l: u:
8 bits counter bit[23:16] 16 bits counter bit[15:0] 16 bits counter bit[31:16]
11.2 11.2.1
IEEE 802.3 HUB Management (RFC 1516) Event Counters Readablectet
11.2.1.1
Counts number of bytes (i.e. octets) contained in good valid frames received. Frame size: > 64 bytes, < 1522 bytes if VLAN Tagged; 1518 bytes if not VLAN Tagged No FCS (i.e. checksum) error No collisions
61
Zarlink Semiconductor Inc.
ZL50416
11.2.1.2 ReadableFrame
Data Sheet
Counts number of good valid frames received. Frame size: > 64 bytes, < 1522 bytes if VLAN Tagged; 1518 bytes if not VLAN Tagged No FCS error No collisions
11.2.1.3
FCSErrors
Counts number of valid frames received with bad FCS. Frame size: > 64 bytes, < 1522 bytes if VLAN Tagged; 1518 bytes if not VLAN Tagged No framing error No collisions
11.2.1.4
AlignmentErrors
Counts number of valid frames received with bad alignment (not byte-aligned). Frame size: > 64 bytes, < 1522 bytes if VLAN Tagged; 1518 bytes if not VLAN Tagged No framing error No collisions
11.2.1.5
FrameTooLongs
Counts number of frames received with size exceeding the maximum allowable frame size. Frame size: > 64 bytes, > 1522 bytes if VLAN Tagged; 1518 bytes if not VLAN Tagged FCS error: Framing error: No collisions don't care don't care
11.2.1.6
ShortEvents
Counts number of frames received with size less than the length of a short event. Frame size: FCS error: < 10 bytes don't care
62
Zarlink Semiconductor Inc.
ZL50416
Framing error: No collisions don't care
Data Sheet
11.2.1.7
Runts
Counts number of frames received with size under 64 bytes, but greater than the length of a short event. Frame size: FCS error: Framing error: No collisions > 10 bytes, don't care don't care < 64 bytes
11.2.1.8
Collisions
Counts number of collision events. Frame size: any size
11.2.1.9
LateEvents
Counts number of collision events that occurred late (after LateEventThreshold = 64 bytes). Frame size: any size
Events are also counted by collision counter
11.2.1.10
VeryLongEvents
Counts number of frames received with size larger than Jabber Lockup Protection Timer (TW3). Frame size: > Jabber
11.2.1.11
DataRateMisatches
For repeaters or HUB application only.
11.2.1.12
AutoPartitions
For repeaters or HUB application only.
11.2.1.13
TotalErrors
Sum of the following errors: FCS errors Alignment errors Frame too long Short events Late events Very long events
63
Zarlink Semiconductor Inc.
ZL50416
11.3 11.3.1 11.3.1.1 IEEE 802.1 Bridge Management (RFC 1286) Event Counters InFrames
Data Sheet
Counts number of frames received by this port or segment. Note: A frame received by this port is only counted by this counter if and only if it is for a protocol being processed by the local bridge function.
11.3.1.2
OutFrames
Counts number of frames transmitted by this port. Note: A frame transmitted by this port is only counted by this counter if and only if it is for a protocol being processed by the local bridge function.
11.3.1.3
InDiscards
Counts number of valid frames received which were discarded (i.e., filtered) by the forwarding process.
11.3.1.4
DelayExceededDiscards
Counts number of frames discarded due to excessive transmit delay through the bridge.
11.3.1.5
MtuExceededDiscards
Counts number of frames discarded due to excessive size.
11.4 11.4.1
RMON - Ethernet Statistic Group (RFC 1757) Event Counters Drop Events
11.4.1.1
Counts number of times a packet is dropped, because of lack of available resources. DOES NOT include all packet dropping -- for example, random early drop for quality of service support.
11.4.1.2
Octets
Counts the total number of octets (i.e. bytes) in any frames received.
11.4.1.3
BroadcastPkts
Counts the number of good frames received and forwarded with broadcast address. Does not include non-broadcast multicast frames.
11.4.1.4
MulticastPkts
Counts the number of good frames received and forwarded with multicast address. Does not include broadcast frames.
64
Zarlink Semiconductor Inc.
ZL50416
11.4.1.5 CRCAlignErrors
> 64 bytes,
Data Sheet
Frame size: No collisions:
< 1522 bytes if VLAN tag (1518 if no VLAN)
Counts number of frames received with FCS or alignment errors
11.4.1.6
UndersizePkts
Counts number of frames received with size less than 64 bytes. Frame size: No FCS error No framing error No collisions < 64 bytes,
11.4.1.7
OversizePkts
Counts number of frames received with size exceeding the maximum allowable frame size. Frame size: FCS error Framing error No collisions 1522 bytes if VLAN tag (1518 bytes if no VLAN) don't care don't care
11.4.1.8
Fragments
Counts number of frames received with size less than 64 bytes and with bad FCS. Frame size: Framing error No collisions < 64 bytes don't care
11.4.1.9
Jabbers
Counts number of frames received with size exceeding maximum frame size and with bad FCS. Frame size: Framing error No collisions > 1522 bytes if VLAN tag (1518 bytes if no VLAN) don't care
65
Zarlink Semiconductor Inc.
ZL50416
11.4.1.10 Collisions
Data Sheet
Counts number of collision events detected. Only a best estimate since collisions can only be detected while in transmit mode, but not while in receive mode. Frame size: any size
11.4.1.11
Packet Count for Different Size Groups
Six different size groups - one counter for each: Pkts64Octets Pkts65to127Octets Pkts128to255Octets Pkts256to511Octets Pkts512to1023Octets for any packet with size = 64 bytes for any packet with size from 65 bytes to 127 bytes for any packet with size from 128 bytes to 255 bytes for any packet with size from 256 bytes to 511 bytes for any packet with size from 512 bytes to 1023 bytes
Pkts1024to1518Octets for any packet with size from 1024 bytes to 1518 bytes Counts both good and bad packets.
11.5
Miscellaneous Counters
In addition to the statistics groups defined in previous sections, the ZL50416 has other statistics counters for its own purposes. We have two counters for flow control - one counting the number of flow control frames received, and another counting the number of flow control frames sent. We also have two counters, one for unicast frames sent and one for non-unicast frames sent. A broadcast or multicast frame qualifies as non-unicast. Furthermore, we have a counter called "frame send fail." This keeps track of FIFO under-runs, late collisions and collisions that have occurred 16 times.
66
Zarlink Semiconductor Inc.
ZL50416 12.0
12.1
Data Sheet
Register Definition
Register Description
Register Description CPU Addr (Hex) R/W I2C Addr (Hex) Default Notes
0. Ethernet Port Control Registers (substitute n with port number (0..Fh)) ECR1Pn ECR2Pn Port Control Register 1 for Port n Port Control Register 2 for Port n 000+2n 001+2n R/W R/W 000+n 01B+n 0C0 000
1. VLAN Control Registers (substitute n with port number (0..Fh)) AVTCL AVTCH PVMAPn_0 PVMAPn_1 PVMAPn_2 PVMAPn_3 PVMODE PVROUTE[7:0] VLAN Type Code Register Low VLAN Type Code Register High Port n Configuration Register 0 Port n Configuration Register 1 Port n Configuration Register 2 Port n Configuration Register 3 VLAN Operating Mode VLAN Router Group Enable 100 101 102+4n 103+4n 104+4n 105+4n 170 171-178 R/W R/W R/W R/W R/W R/W R/W R/W 036 037 038+n 053+n 06E+n 089+n 0A4 NA 000 081 0FF 0FF 0FF 007 000 000
2. TRUNK Control Registers TRUNK0_L TRUNK0_M TRUNK0_H TRUNK0_MODE TRUNK0_HASH0 TRUNK0_HASH1 TRUNK0_HASH2 TRUNK0_HASH3 TRUNK1_L TRUNK1_M TRUNK1_H TRUNK1_MODE Trunk Group 0 Low Trunk Group 0 Medium Trunk Group 0 High Trunk Group 0 Mode Trunk Group 0 Hash 0 Destination Port Trunk Group 0 Hash 1 Destination Port Trunk Group 0 Hash 2 Destination Port Trunk Group 0 Hash 3 Destination Port Trunk Group 1 Low Trunk Group 1 Medium Trunk Group 1 High Trunk Group 1 Mode 200 201 202 203 204 205 206 207 208 209 20A 20B R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W NA NA NA 0A5 NA NA NA NA NA NA NA 0A6 000 000 000 003 000 001 002 003 000 000 000 003
67
Zarlink Semiconductor Inc.
ZL50416
CPU Addr (Hex) 20C 20D 20E 20F 210 211 212 220+4n 221+4n 222+4n 223+4n I2C Addr (Hex) NA NA NA NA NA NA NA NA NA NA NA
Data Sheet
Default Notes
Register TRUNK1_HASH0 TRUNK1_HASH1 TRUNK1_HASH2 TRUNK1_HASH3 TRUNK2_MODE TRUNK2_HASH0 TRUNK2_HASH1 MULTICAST_HA SHn-0 MULTICAST_HA SHn-1 MULTICAST_HA SHn-2 MULTICAST_HA SHn-3
Description Trunk Group 1 Hash 0 Destination Port Trunk Group 1 Hash 1 Destination Port Trunk Group 1 Hash 2 Destination Port Trunk Group 1 Hash 3 Destination Port Trunk Group 2 Mode Trunk Group 2 Hash 0 Destination Port Trunk Group 2 Hash 1 Destination Port Multicast hash result n mask byte 0 Multicast hash result n mask byte 1 Multicast hash result n mask byte 2 Multicast hash result n mask byte 3
R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W
004 005 006 007 003 019 01A 0FF 0FF 0FF 0FF n = hash result (0..3)
3. CPU Port Configuration MAC0 MAC1 MAC2 MAC3 MAC4 MAC5 INT_MASK0 INTP_MASKn RQS RQSS TX_AGE CPU MAC Address byte 0 CPU MAC Address byte 1 CPU MAC Address byte 2 CPU MAC Address byte 3 CPU MAC Address byte 4 CPU MAC Address byte 5 Interrupt Mask 0 Interrupt Mask for MAC Port 2n, 2n+1 Receive Queue Select Receive Queue Status Transmission Queue Aging Time 300 301 302 303 304 305 306 310+n 323 324 325 R/W R/W R/W R/W R/W R/W R/W R/W R/W RO R/W NA NA NA NA NA NA NA NA NA NA 0A7 000 000 000 000 000 000 000 000 000 NA 008 (n=0..7)
68
Zarlink Semiconductor Inc.
ZL50416
CPU Addr (Hex) I2C Addr (Hex)
Data Sheet
Default Notes
Register
Description
R/W
4. Search Engine Configurations AGETIME_LOW AGETIME_HIGH V_AGETIME SE_OPMODE SCAN MAC Address Aging Time Low MAC Address Aging Time High VLAN to Port Aging Time Search Engine Operating Mode Scan control register 400 401 402 403 404 R/W R/W R/W R/W R/W 0A8 0A9 NA NA NA 2M:05C/ 4M:02E 000 0FF 000 000
5. Buffer Control and QOS Control FCBAT QOSC FCR AVPML AVPMM AVPMH TOSPML TOSPMM TOSPMH AVDM TOSDML BMRC UCC MCC PR100 SFCB C2RS C3RS C4RS C5RS C6RS FCB Aging Timer QOS Control Flooding Control Register VLAN Priority Map Low VLAN Priority Map Middle VLAN Priority Map High TOS Priority Map Low TOS Priority Map Middle TOS Priority Map High VLAN Discard Map TOS Discard Map Broadcast/Multicast Rate Control Unicast Congestion Control Multicast Congestion Control Port Reservation for 10/100 Ports Share FCB Size Class 2 Reserve Size Class 3 Reserve Size Class 4 Reserve Size Class 5 Reserve Size Class 6 Reserve Size 500 501 502 503 504 505 506 507 508 509 50A 50B 50C 50D 50E 510 511 512 513 514 515 R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W 0AA 0AB 0AC 0AD 0AE 0AF 0B0 0B1 0B2 0B3 0B4 0B5 0B6 0B7 0B8 0BA 0BB 0BC 0BD 0BE 0BF 0FF 000 008 000 000 000 000 000 000 000 000 000 2M:008/ 4M:010 050 2M:035/ 4M:036 2M:046/ 4M:064 000 000 000 000 000
69
Zarlink Semiconductor Inc.
ZL50416
CPU Addr (Hex) 516 517-51C 51D-522 52F-552 553 554 580+2n 581+2n 590 591 592 593 594 595 596 597 598 599 59A 59B 59C 59D 59E 5A0-5A2 I2C Addr (Hex) 0C0 0C1-0C6 NA NA 0FB 0FC 0D6+n 0DE+n 0E6 0E7 0E8 0E9 0EA 0EB 0EC 0ED 0EE 0EF 0F4 0F5 0D3 0D4 0D5 NA
Data Sheet
Default Notes
Register C7RS QOSCn
Description Class 7 Reserve Size QOS Control (n=0 - 5) QOS Control (n=6 - 11) QOS Control (n=24 - 59)
R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W
000 000 000 000 08F 088 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 (n=0-7)
RDRC0 RDRC1 USER_PORTn_L OW USER_PORTn_H IGH USER_PORT1:0_ PRIORITY USER_PORT3:2_ PRIORITY USER_PORT5:4_ PRIORITY USER_PORT7:6_ PRI ORITY USER_PORT_EN ABLE WLPP10 WLPP32 WLPP54 WLPP76 WLPE RLOWL RLOWH RHIGHL RHIGHH RPRIORITY CPUQOSC1~3
WRED Drop Rate Control 0 WRED Drop Rate Control 1 User Define Logical Port n Low User Define Logical Port n High User Define Logic Port 1 and 0 Priority User Define Logic Port 3 and 2 Priority User Define Logic Port 5 and 4 Priority User Define Logic Port 7 and 6 Priority User Define Logic Port Enable Well known Logic Port Priority for 1 and 0 Well known Logic Port Priority for 3 and 2 Well known Logic Port Priority for 5 and 4 Well-known Logic Port Priority for 7 & 6 Well known Logic Port Enable User Define Range Low Bit7:0 User Define Range Low Bit 15:8 User Define Range High Bit 7:0 User Define Range High Bit 15:8 User Define Range Priority Byte limit for TxQ on CPU port
70
Zarlink Semiconductor Inc.
ZL50416
CPU Addr (Hex) I2C Addr (Hex)
Data Sheet
Default Notes
Register
Description
R/W
6. MISC Configuration Registers MII_OP0 MII_OP1 FEN MIIC0 MIIC1 MIIC2 MIIC3 MIID0 MIID1 LED DEVICE SUM MII Register Option 0 MII Register Option 1 Feature Registers MII Command Register 0 MII Command Register 1 MII Command Register 2 MII Command Register 3 MII Data Register 0 MII Data Register 1 LED Control Register Device id and test EEPROM Checksum Register 600 601 602 603 604 605 606 607 608 609 60A 60B R/W R/W R/W R/W R/W R/W R/W RO RO R/W R/W R/W 0F0 0F1 0F2 NA NA NA NA NA NA 0F3 NA 0FF 000 000 010 000 000 000 000 NA NA 000 000 000
7. Port Mirroring Controls MIRROR1_SRC MIRROR1_DEST MIRROR2_SRC MIRROR2_DEST Port Mirror 1 Source Port Port Mirror 1 Destination Port Port Mirror 2 Source Port Port Mirror 2 Destination Port 700 701 702 703 R/W R/W R/W R/W NA NA NA NA 07F 017 0FF 000
F. Device Configuration Register GCR DCR DPST DTST DA Global Control Register Device Status and Signature Register Device Port Status Register Data read back register Dead or Alive Register F00 F01 F03 F04 FFF R/W RO R/W RO RO NA NA NA NA NA 000 NA 000 NA DA
71
Zarlink Semiconductor Inc.
ZL50416
12.2 Directly Accessed Registers (8/16-bit Access Only)
Width 8/16-bit Default: 00 Access W
Data Sheet
INDEX_REG0
Used to write the address of the indirect register to be accessed. Data is read from/written to register
Address 0
Bit #
Name
Type
Description
16-bit or serial CPU Interface [15:0] INDEX W 16-bit address of the indirect register
8-bit CPU Interface [7:0] INDEX_L W LSB [7:0] of the 16-bit address of the indirect register Register Table 1 - 0, INDEX_REG0
INDEX_REG1
8-bit CPU Interface Only. Used to write the address of the indirect register to be accessed. Data is read from/written to register
Width 8-bit Default: 00
Access W
Address 1
Bit # [7:0]
Name INDEX_H
Type W
Description MSB [15:8] of the 16-bit address of the indirect register
Register Table 2 - 1, INDEX_REG1
DATA_REG
Data of indirectly accessed registers
Width 8-bit Default: 00
Access R/W
Address 2
Bit # [7:0]
Name DATA
Type R/W
Description 8-bit indirect register data
Register Table 3 - 2, DATA_REG
72
Zarlink Semiconductor Inc.
ZL50416 CPU_FRAME_REG
CPU transmit/receive Ethernet frames. Width 8/16-bit Default: 00 Access R/W
Data Sheet
Address 3
Bit #
Name
Type
Description
16-bit or serial CPU Interface [15:0] CPU_FRAME W Send frame from CPU. In sequence format: * Frame Data (size should be in multiple of 8-byte) * R 8-byte of Frame status (Frame size, Destination port #, Frame O.K. status)
CPU Received frame. In sequence format: * 8-byte of Frame status (Frame size, Source port #, VLAN tag) * Frame Data (size should be in multiple of 8-byte)
8-bit CPU Interface [7:0] CPU_FRAME W Send frame from CPU. In sequence format: * Frame Data (size should be in multiple of 8-byte) * R 8-byte of Frame status (Frame size, Destination port #, Frame O.K. status)
CPU Received frame. In sequence format: * 8-byte of Frame status (Frame size, Source port #, VLAN tag) * Frame Data (size should be in multiple of 8-byte)
Register Table 4 - 3, CPU_FRAME_REG
73
Zarlink Semiconductor Inc.
ZL50416 CMD_STATUS_REG
CPU interface commands and status Width 8-bit Default: 00 Access R/W
Data Sheet
Address 4
Bit # [0]
Name CMD_CONTROL_F RAME_TX_DONE STATUS_CONTRO L_FRAME_TX_RDY
Type W R
Description Set Control Frame Receive buffer ready after CPU writes a complete frame into the buffer. This bit is self-cleared. Control Frame receive buffer ready, CPU can write a new frame 1 - CPU can write a new control command 0 - CPU has to wait until this bit is 1 to write a new control command Set Control Frame Transmit buffer1 ready after CPU reads out a complete frame from the buffer. This bit is self-cleared. Control Frame transmit buffer1 ready for CPU to read 1 - CPU can read a new control command 1 0 - CPU has to wait until this bit is 1 to read a new control command Set Control Frame Transmit buffer2 ready after CPU reads out a complete frame from the buffer. This bit is self-cleared. Control Frame transmit buffer2 ready for CPU to read 1 - CPU can read a new control command 2 0 - CPU has to wait until this bit is 1 to read a new control command Set this bit to indicate that the CPU received a whole Ethernet frame (transmit FIFO frame receive done), and flushed the rest of frame fragment, if occurs. This bit is self-cleared. Transmit FIFO has data for CPU to read (TXFIFO_RDY) Set this bit to indicate that the following Write to the Receive FIFO is the last one (EOF). This bit is self-cleared. Receive FIFO has space for incoming CPU Ethernet frame (RXFIFO_SPOK) Set this bit to re-start the data that is sent from the CPU to Receive FIFO (re-align). This feature can be used for software debug. For normal operation must be '0'. Transmit FIFO End Of Frame (TXFIFO_EOF) Reserved
[1]
CMD_CONTROL_F RAME_BUF1_RX_ DONE STATUS_CONTRO L_FRAME_RX_BUF 1_RDY
W
R
[2]
CMD_CONTROL_F RAME_BUF2_RX_ DONE STATUS_CONTRO L_FRAME_RX_BUF 2_RDY
W
R
[3]
CMD_CPU_FRAME _TX_DONE_AND_F LUSH STATUS_CPU_FRA ME_TX_BUF_RDY
W
R W R W
[4]
CMD_LAST_BYTE_ WRITE STATUS_CPU_FRA ME_RX_BUF_RDY
[5]
CMD_RESTART_R X_FIFO STATUS_CPU_FRA ME_TX_EOF
R R/W
[7:6]
RSVD
Register Table 5 - 4, CMD_STATUS_REG
74
Zarlink Semiconductor Inc.
ZL50416
Data Sheet
INT_REG
Interrupt sources Note: This register is not self-cleared. After reading CPU has to clear the bit writing 0 to it.
Width 8-bit Default: N/A
Access R/W
Address 5
Bit # [0] [1] [2] [7:3]
Name INT_CPU_FRAME INT_CONTROL_FR AME1 INT_CONTROL_FR AME2 RSVD
Type R/W R/W R/W R/W
Description Ethernet frame interrupt. Ethernet Frame receive buffer has data for CPU to read Control Frame 1 interrupt. Control Frame receive buffer1 has data for CPU to read Control Frame 2 interrupt. Control Frame receive buffer2 has data for CPU to read Reserved Register Table 6 - 5, INT_REG
CONTROL_FRM_BUFFER1
CPU transmit/receive control frames to/from buffer 1.
Width 8/16-bit Default: 00
Access R/W
Address 6
Bit #
Name
Type
Description
16-bit or serial CPU Interface [15:0] CTRL_FRAME1 W R 8-bit CPU Interface [7:0] CTRL_FRAME1 W R Send frame from CPU. CPU received frame from buffer 1 Send frame from CPU. CPU received frame from buffer 1
Register Table 7 - 6, CONTROL_FRM_BUFFER1
CONTROL_FRM_BUFFER2
CPU receive control frames from buffer 2.
Width 8/16-bit Default: 00
Access R
Address 7
Bit #
Name
Type
Description
16-bit or serial CPU Interface [15:0] CTRL_FRAME2 R CPU received frame from buffer 2
8-bit CPU Interface [7:0] CTRL_FRAME2 R CPU received frame from buffer 2
Register Table 8 - 7, CONTROL_FRM_BUFFER2
75
Zarlink Semiconductor Inc.
ZL50416
12.3 12.3.1 12.3.1.1 Indirectly Accessed Registers (Group 0 Address) MAC Ports Group ECR1Pn: Port n Control Register 1
Data Sheet
I2C Address 000+n; CPU Address:0000+2n (n = port number) Accessed by CPU, serial interface and I2C (R/W) 7 SS Bit [0] Bit [1] Bit [2] Bit [4:3] 6 5 A-FC 4 Port Mode 0
1 - Flow Control Disabled 0 - Flow Control Enabled (Default) 1 - Half Duplex 0 - Full Duplex (Default) 1 - 10 Mbps 0 - 100 Mbps (Default) 00 - Enable Auto-Negotiation This enables hardware state machine for auto-negotiation. (Default) 01 - Limited Disable Auto-Negotiation This disables hardware state machine for speed auto-negotiation (use ECR1Pn[2:0] for configuration). Hardware will still poll PHY for link status. 10 - Force Link Down Disable the port. Hardware does not talk to PHY. 11 - Force Link Up The configuration in ECR1Pn[2:0] is used for (speed/duplex/flow control) setup. Hardware does not talk to PHY. Asymmetric Flow Control Enable. 0 - Disable asymmetric flow control (Default) 1 - Enable Asymmetric flow control When this bit is set and flow control is on (bit [0] = 0), the device does not send out flow control frames, but it's receiver interprets and processes flow control frames.
Bit [5]
Bit [7:6]
SS - Spanning tree state (IEEE 802.1D spanning tree protocol) 00 - Blocking: Frame is dropped 01 - Listening: Frame is dropped 10 - Learning: Frame is dropped. Source MAC address is learned. 11 - Forwarding: Frame is forwarded. Source MAC address is learned. (Default)
12.3.1.2
ECR2Pn: Port n Control Register 2
I2C Address: 01B+n; CPU Address:0001+2n (n = port number) Accessed by CPU and serial interface (R/W) 7 6 5 4 3 2 DisL 1 Ftf 0 Futf
Security En
QoS Sel
76
Zarlink Semiconductor Inc.
ZL50416
Bit [0]:
Data Sheet
Filter untagged frame 0: Disable (Default) 1: All untagged frames from this port are discarded or follow security option when security is enable Filter Tag frame 0: Disable (Default) 1: All tagged frames from this port are discarded or follow security option when security is enable Learning Disable 0: Learning is enabled on this port (Default) 1: Learning is disabled on this port Must be `1' QOS mode selection. Determines which of the 4 sets of QoS settings is used for 10/100 ports.
* * * * 00: select class byte limit set 0 and classes WFQ credit set 0 (Default) 01: select class byte limit set 1 and classes WFQ credit set 1 10: select class byte limit set 2 and classes WFQ credit set 2 11: select class byte limit set 3 and classes WFQ credit set 3
Bit [1]:
Bit [2]:
Bit [3]: Bit [5:4]
Note that there are 4 sets of per-queue byte thresholds, and 4 sets of WFQ ratios programmed. These bits select among the 4 choices for each 10/100 port. Refer to Programming QOS Registers Application Note, ZLAN-05. Bit[7:6] Security Enable. The ZL50416 checks the incoming data for one of the following conditions: * If the source MAC address of the incoming packet is in the MAC table and is defined as secure address but the ingress port is not the same as the port associated with the MAC address in the MAC table. * A MAC address is defined as secure when its entry at MAC table has static status and bit 0 is set to 1. MAC address bit 0 (the first bit transmitted) indicates whether the address is unicast or multicast. As source addresses are always unicast bit 0 is not used (always 0). ZL50416 uses this bit to define secure MAC addresses. * If the port is set as learning disable and the source MAC address of the incoming packet is not defined in the MAC address table or the MAC address is not associated to the ingress port. * If the port is configured to filter untagged frames and an untagged frame arrives * If the port is configured to filter tagged frames and a tagged frame arrives If any one of the conditions is met, the packet is forwarded based on these setting. 00 - Disable port security, forward packets as usual. (Default) 01 - Discard violating packets 10 - Forward violating packets as usual and also to the CPU for inspection 11 - Forward violating packets to the CPU for inspection
77
Zarlink Semiconductor Inc.
ZL50416
12.3.2 12.3.2.1 (Group 1 Address) VLAN Group AVTCL - VLAN Type Code Register Low
Data Sheet
I2C Address 036; CPU Address:h100 Accessed by CPU, serial interface and I2C (R/W) Bit [7:0]: VLANType_LOW: Lower 8 bits of the VLAN type code (Default 00)
12.3.2.2
AVTCH - VLAN Type Code Register High
I2C Address 037; CPU Address:h101 Accessed by CPU, serial interface and I2C (R/W) Bit [7:0]: VLANType_HIGH: Upper 8 bits of the VLAN type code (Default 0x81)
12.3.2.3
PVMAP00_0 - Port 00 Configuration Register 0
I2C Address 038, CPU Address:h102 Accessed by CPU, serial interface and I2C (R/W) In Port-based VLAN Mode Bit [7:0]: VLAN Mask for ports 7 to 0 (Default 0xFF) This register indicates the legal egress ports. A "1" on bit 7 means that the packet can be sent to port 7. A "0" on bit 7 means that any packet destined to port 7 will be discarded. This register works with registers 1, 2 and 3 to form a 27 bit mask to all egress ports. In Tagged-based VLAN Mode Bit [7:0]: PVID [7:0] (Default is 0xFF) This is the default VLAN tag. It works with configuration register PVMAP00_1 [7:5] [3:0] to form a default VLAN tag. If the received packet is untagged, then the packet is classified with the default VLAN tag. If the received packet has a VLAN ID of 0, then PVID is used to replace the packet's VLAN ID.
78
Zarlink Semiconductor Inc.
ZL50416
12.3.2.4 PVMAP00_1 - Port 00 Configuration Register 1
Data Sheet
I2C Address h53, CPU Address:h103 Accessed by CPU, serial interface and I2C (R/W) In Port-based VLAN Mode Bit [7:0]: VLAN Mask for ports 15 to 8 (Default 0xFF)
In Tagged-based VLAN Mode 7 5 4 Ultrust 3 PVID 0
Unitag Port Priority Bit [3:0]: Bit [4]:
PVID [11:8] (Default is 0xF) Untrusted Port. (Default is 1) This register is used to change the VLAN priority field of a packet to a predetermined priority. 1: VLAN priority field is changed to Bit [7:5] at ingress port 0: Keep VLAN priority field Untag Port Priority (Default 0x7)
Bit [7:5]:
12.3.2.5
PVMAP00_2 - Port 00 Configuration Register 2
I2C Address h6E, CPU Address:h104 Accessed by CPU, serial interface and I2C (R/W) In Port-based VLAN Mode Bit [7:0]: * Reserved (Default FF)
In Tagged-based VLAN Mode This registered is unused
12.3.2.6
PVMAP00_3 - Port 00 Configuration Register 3
I2C Address h89, CPU Address:h105 Accessed by CPU, serial interface and I2C (R/W) In Port-based VLAN Mode Bit [0]: Bit [2:1]: VLAN Mask for port 24 (CPU) (Default 1) Reserved (Default 3)
79
Zarlink Semiconductor Inc.
ZL50416
Bit [5:3]: Default Transmit priority. Used when Bit [7] = 1 (Default 0)
* * * * * * * * 000 001 010 011 100 101 110 111 Transmit Priority Level 0 (Lowest) Transmit Priority Level 1 Transmit Priority Level 2 Transmit Priority Level 3 Transmit Priority Level 4 Transmit Priority Level 5 Transmit Priority Level 6 Transmit Priority Level 7 (Highest)
Data Sheet
Bit [6]:
Default Discard priority. Used when Bit[7]=1 (Default 0)
* 0 - Discard Priority Level 0 (Lowest) * 1 - Discard Priority Level 1(Highest)
Bit [7]:
Enable Fix Priority (Default 0)
* 0 Disable fix priority. All frames are analyzed. Transmit Priority and Discard Priority are based on VLAN Tag, TOS or Logical Port. * 1 Transmit Priority and Discard Priority are based on values programmed in bit [6:3]
In Tag-based VLAN Mode Bit [0]: Bit [1]: Not used Ingress Filter Enable 0 - Disable Ingress Filter. Packets with VLAN not belonging to source port are forwarded, if destination port belongs to the VLAN. Symmetric VLAN. (Default) 1 - Enable Ingress Filter. Packets with VLAN not belonging to source port are filtered. Asymmetric VLAN. Force untag out (VLAN tagging is based on IEEE 802.1Q rule). 0 - Disable (Default) 1 - Force untagged output. All packets transmitted from this port are untagged. This bit is used when this port is connected to legacy equipment that does not support VLAN tagging. Bit [5:3]: Default Transmit priority. Used when Bit [7] = 1 (Default 0)
* * * * * * * * 000 001 010 011 100 101 110 111 Transmit Priority Level 0 (Lowest) Transmit Priority Level 1 Transmit Priority Level 2 Transmit Priority Level 3 Transmit Priority Level 4 Transmit Priority Level 5 Transmit Priority Level 6 Transmit Priority Level 7 (Highest)
Bit [2]:
Bit [6]:
Default Discard priority. Used when Bit [7]=1 0 - Discard Priority Level 0 (Lowest) (Default) 1 - Discard Priority Level 1(Highest)
80
Zarlink Semiconductor Inc.
ZL50416
Bit [7]:
Data Sheet
Enable Fix Priority (Default 0) 0 - Disable. All frames are analysed. Transmit Priority and Discard Priority are based on VLAN Tag, TOS or Logical Port. 1 - Enable. Transmit Priority and Discard Priority are based on values programmed in bit [6:3]
12.3.2.7
PVMAPnn_0,1,2,3 - Port nn Configuration Registers
PVMAP01_0,1,2,3 I2C Address h39,54,6F,8A; CPU Address:h106,107,108,109 (Port 1) PVMAP02_0,1,2,3 I2C Address h3A,55,70,8B; CPU Address:h10A, 10B, 10C, 10D (Port 2) PVMAP03_0,1,2,3 I2C Address h3B,56,71,8C; CPU Address:h10E, 10F, 110, 111 (Port 3) PVMAP04_0,1,2,3 I2C Address h3C,57,72,8D; CPU Address:h112, 113, 114, 115 (Port 4) PVMAP05_0,1,2,3 I2C Address h3D,58,73,8E; CPU Address:h116, 117, 118, 119 (Port 5) PVMAP06_0,1,2,3 I2C Address h3E,59,74,8F; CPU Address:h11A, 11B, 11C, 11D (Port 6) PVMAP07_0,1,2,3 I2C Address h3F,5A,75,90; CPU Address:h11E, 11F, 120, 121 (Port 7) PVMAP08_0,1,2,3 I2C Address h40,5B,76,91; CPU Address:h122, 123, 124, 125 (Port 8) PVMAP09_0,1,2,3 I2C Address h41,5C,77,92; CPU Address:h126, 127, 128, 129 (Port 9) PVMAP10_0,1,2,3 I2C Address h42,5D,78,93; CPU Address:h12A, 12B, 12C, 12D (Port 10) PVMAP11_0,1,2,3 I2C Address h43,5E,79,94; CPU Address:h12E, 12F, 130, 131 (Port 11) PVMAP12_0,1,2,3 I2C Address h44,5F,7A,95; CPU Address:h132, 133, 134, 135 (Port 12) PVMAP13_0,1,2,3 I2C Address h45,60,7B,96; CPU Address:h136, 137, 138, 139 (Port 13) PVMAP14_0,1,2,3 I2C Address h46,61,7C,97; CPU Address:h13A, h13B, 13C, 13D (Port 14) PVMAP15_0,1,2,3 I2C Address h47,62,7D,98; CPU Address:h13E, 13F, 140, 141 (Port 15) PVMAP24_0,1,2,3 I2C Address h50,6B,86,A1; CPU Address:h162, 163, 164, 165 (Port 24 - CPU port)
81
Zarlink Semiconductor Inc.
ZL50416
12.3.2.8 PVMODE
Data Sheet
I2C Address: h0A4, CPU Address:h170 Accessed by CPU, serial interface (R/W) 7 MAC05 Bit [0]: * 6 MMA 5 STP 4 SM0 3 2 DF 1 SL 0 Vmod
VLAN Mode (Default = 0)
* 1 Tagged-based VLAN Mode * 0 Port-based VLAN Mode
Bit [1]:
*
Slow learning (Default = 0) Same function as SE_OP MODE bit 7. Either bit can enable the function; both need to be turned off to disable the feature. Disable dropping of frames with destination MAC addresses 0180C2000001 to 0180C200000F (Default = 0)
* 0: Drop all frames in this range * 1: Disable dropping of frames in this range
Bit [2]:
*
Bit [3]: Bit [4]: *
* Reserved Support MAC address 0 (Default = 0)
* 0: MAC address 0 is not learned. * 1: MAC address 0 is learned.
Bit [5]:
*
Disable IEEE multicast control frame (0180C2000000 to 0180C200000F) to CPU in managed mode (Default = 0)
* 0: Packet is forwarded to CPU * 1: Packet is forwarded as multicast
Bit [6]:
*
Multiple MAC addresses (Default = 0)
* 0: Single MAC address is assigned to CPU. Registers MAC0 to MAC5 are used to program the CPU MAC address. * 1: One block of 32 MAC addresses are assigned to CPU. The block is defined in an increase way from the MAC address programmed in registers MAC0 to MAC5.
Bit [7]:
*
Disable registers MAC 5 - 0 (CPU MAC address) in comparison with Ethernet frame destination MAC address. When disable, unicast frames are not forward to CPU. (Default = 0)
* 1: Disable * 0: Enable
12.3.2.9
PVROUTE0
Registers PVROUTE0 to PVROUTE7 allows the VLAN Index to be assigned an address of a router group. This feature is useful during IP Multicast mode when data is being sent to the VLAN group and no member of the group registers. By assigning a router group the VLAN group always has a default address to handle the multicast traffic.
82
Zarlink Semiconductor Inc.
ZL50416
CPU Address:h171 Accessed by CPU, serial interface (R/W) Bit [0]: Bit [1]: Bit [2]: Bit [3]: Bit [4]: Bit [5]: Bit [6]: Bit [7]: * * * * * * * *
Data Sheet
VLAN Index 8'hC0 has router group and the router group is VLAN Index 8'h40 VLAN Index 8'hC1 has router group and the router group is VLAN Index 8'h41 VLAN Index 8'hC2 has router group and the router group is VLAN Index 8'h42 VLAN Index 8'hC3 has router group and the router group is VLAN Index 8'h43 VLAN Index 8'hC4 has router group and the router group is VLAN Index 8'h44 VLAN Index 8'hC5 has router group and the router group is VLAN Index 8'h45 VLAN Index 8'hC6 has router group and the router group is VLAN Index 8'h46 VLAN Index 8'hC7 has router group and the router group is VLAN Index 8'h47
12.3.2.10
PVROUTE1
CPU Address:h172 Accessed by CPU, serial interface (R/W) Bit [0]: Bit [1]: Bit [2]: Bit [3]: Bit [4]: Bit [5]: Bit [6]: Bit [7]: * * * * * * * * VLAN Index 8'hC8 has router group and the router group is VLAN Index 8'h48 VLAN Index 8'hC9 has router group and the router group is VLAN Index 8'h48 VLAN Index 8'hCA has router group and the router group is VLAN Index 8'h4A VLAN Index 8'hCB has router group and the router group is VLAN Index 8'h4B VLAN Index 8'hCC has router group and the router group is VLAN Index 8'h4C VLAN Index 8'hCD has router group and the router group is VLAN Index 8'h4D VLAN Index 8'hCE has router group and the router group is VLAN Index 8'h4E VLAN Index 8'hCF has router group and the router group is VLAN Index 8'h4F
12.3.2.11
PVROUTE2
CPU Address:h173 Accessed by CPU, serial interface (R/W) Bit [0]: Bit [1]: Bit [2]: Bit [3]: Bit [4]: Bit [5]: Bit [6]: Bit [7]: * * * * * * * * VLAN Index 8'hD0 has router group and the router group is VLAN Index 8'h50 VLAN Index 8'hD1 has router group and the router group is VLAN Index 8'h51 VLAN Index 8'hD2 has router group and the router group is VLAN Index 8'h52 VLAN Index 8'hD3 has router group and the router group is VLAN Index 8'h53 VLAN Index 8'hD4 has router group and the router group is VLAN Index 8'h54 VLAN Index 8'hD5 has router group and the router group is VLAN Index 8'h55 VLAN Index 8'hD6 has router group and the router group is VLAN Index 8'h56 VLAN Index 8'hD7 has router group and the router group is VLAN Index 8'h57
83
Zarlink Semiconductor Inc.
ZL50416
12.3.2.12 PVROUTE3
Data Sheet
CPU Address:h174 Accessed by CPU, serial interface (R/W) Bit [0]: Bit [1]: Bit [2]: Bit [3]: Bit [4]: Bit [5]: Bit [6]: Bit [7]: * * * * * * * * VLAN Index 8'hD8 has router group and the router group is VLAN Index 8'h58 VLAN Index 8'hD9 has router group and the router group is VLAN Index 8'h59 VLAN Index 8'hDA has router group and the router group is VLAN Index 8'h5A VLAN Index 8'hDB has router group and the router group is VLAN Index 8'h5B VLAN Index 8'hDC has router group and the router group is VLAN Index 8'h5C VLAN Index 8'hDD has router group and the router group is VLAN Index 8'h5D VLAN Index 8'hDE has router group and the router group is VLAN Index 8'h5E VLAN Index 8'hDF has router group and the router group is VLAN Index 8'h5F
12.3.2.13
PVROUTE4
CPU Address:h175 Accessed by CPU, serial interface (R/W) Bit [0]: Bit [1]: Bit [2]: Bit [3]: Bit [4]: Bit [5]: Bit [6]: Bit [7]: * * * * * * * * VLAN Index 8'hE0 has router group and the router group is VLAN Index 8'h60 VLAN Index 8'hE1 has router group and the router group is VLAN Index 8'h61 VLAN Index 8'hE2 has router group and the router group is VLAN Index 8'h62 VLAN Index 8'hE3 has router group and the router group is VLAN Index 8'h63 VLAN Index 8'hE4 has router group and the router group is VLAN Index 8'h64 VLAN Index 8'hE5 has router group and the router group is VLAN Index 8'h65 VLAN Index 8'hE6 has router group and the router group is VLAN Index 8'h66 VLAN Index 8'hE7 has router group and the router group is VLAN Index 8'h67
12.3.2.14
PVROUTE5
CPU Address:h176 Accessed by CPU, serial interface (R/W) Bit [0]: Bit [1]: Bit [2]: Bit [3]: Bit [4]: Bit [5]: Bit [6]: Bit [7]: * * * * * * * * VLAN Index 8'hE8 has router group and the router group is VLAN Index 8'h68 VLAN Index 8'hE9 has router group and the router group is VLAN Index 8'h69 VLAN Index 8'hEA has router group and the router group is VLAN Index 8'h6A VLAN Index 8'hEB has router group and the router group is VLAN Index 8'h6B VLAN Index 8'hEC has router group and the router group is VLAN Index 8'h6C VLAN Index 8'hED has router group and the router group is VLAN Index 8'h6D VLAN Index 8'hEE has router group and the router group is VLAN Index 8'h6E VLAN Index 8'hEF has router group and the router group is VLAN Index 8'h6F
84
Zarlink Semiconductor Inc.
ZL50416
12.3.2.15 PVROUTE6
Data Sheet
CPU Address:h177 Accessed by CPU, serial interface (R/W) Bit [0]: Bit [1]: Bit [2]: Bit [3]: Bit [4]: Bit [5]: Bit [6]: Bit [7]: * * * * * * * * VLAN Index 8'hF0 has router group and the router group is VLAN Index 8'h70 VLAN Index 8'hF1 has router group and the router group is VLAN Index 8'h71 VLAN Index 8'hF2 has router group and the router group is VLAN Index 8'h72 VLAN Index 8'hF3 has router group and the router group is VLAN Index 8'h73 VLAN Index 8'hF4 has router group and the router group is VLAN Index 8'h74 VLAN Index 8'hF5 has router group and the router group is VLAN Index 8'h75 VLAN Index 8'hF6 has router group and the router group is VLAN Index 8'h76 VLAN Index 8'hF7 has router group and the router group is VLAN Index 8'h77
12.3.2.16
PVROUTE7
CPU Address:h178 Accessed by CPU, serial interface (R/W) Bit [0]: Bit [1]: Bit [2]: Bit [3]: Bit [4]: Bit [5]: Bit [6]: Bit [7]: * * * * * * * * VLAN Index 8'hF8 has router group and the router group is VLAN Index 8'h78 VLAN Index 8'hF9 has router group and the router group is VLAN Index 8'h79 VLAN Index 8'hFA has router group and the router group is VLAN Index 8'h7A VLAN Index 8'hFB has router group and the router group is VLAN Index 8'h7B VLAN Index 8'hFC has router group and the router group is VLAN Index 8'h7C VLAN Index 8'hFD has router group and the router group is VLAN Index 8'h7D VLAN Index 8'hFE has router group and the router group is VLAN Index 8'h7E VLAN Index 8'hFF has router group and the router group is VLAN Index 8'h7F
85
Zarlink Semiconductor Inc.
ZL50416
12.3.3 (Group 2 Address) Port Trunking Groups
Data Sheet
Up to four 10/100 ports can be selected for trunk group 0 and 1. TRUNK0_H, TRUNK0_M, and TRUNK0_L provide a trunk map for trunk0. If ports 0 and 2 are to be trunked together bit 0 and bit 2 of TRUNK0_L are set to 1. All others are clear at "0" to indicate that they are not part of trunk 0. B i t 7 TRUNK0_H P o r t 1 5 B i t 0 B i t 7 TRUNK0_M P o r t 8 P o r t 7 B i t 0 B i t 7 TRUNK0_L P o r t 0 B i t 0
12.3.3.1
TRUNK0_L - Trunk group 0 Low (Managed mode only)
CPU Address:h200 Accessed by CPU, serial interface (R/W) Bit [7:0]: Port7-0 bit map of trunk 0. (Default 00)
12.3.3.2
TRUNK0_M - Trunk group 0 Medium (Managed mode only)
CPU Address:h201 Accessed by CPU, serial interface (R/W) Bit [7:0]: Port15-8 bit map of trunk 0. (Default 00)
12.3.3.3
TRUNK0_H - Trunk group 0 High (Managed mode only)
CPU Address:h202 Accessed by CPU, serial interface (R/W) Bit [7:0]: Reserved (Default 00)
12.3.3.4
TRUNK0_MODE- Trunk group 0 mode
I2C Address h0A5; CPU Address:203 Accessed by CPU, serial interface and I2C (R/W) 7 4 3 Hash Select 2 1 Port Select 0
86
Zarlink Semiconductor Inc.
ZL50416
Bit [1:0]: *
Data Sheet
Port selection in unmanaged mode. Input pin TRUNK0 enable/disable trunk group 0 in unmanaged mode. 00 Reserved 01 Port 0 and 1 are used for trunk0 10 Port 0,1 and 2 are used for trunk0 11 Port 0,1,2 and 3 are used for trunk0
Bit [3:2]
*
Hash Select. The Hash selected is valid for Trunk 0, 1 and 2. (Default 00) 00 Use Source and Destination Mac Address for hashing 01 Use Source Mac Address for hashing 10 Use Destination Mac Address for hashing 11 Use source destination MAC address and ingress physical port number for hashing
12.3.3.5
TRUNK0_HASH0 - Trunk group 0 hash result 0 destination port number
CPU Address:h204 Accessed by CPU, serial interface (R/W) Bit [4:0] Hash result 0 destination port number (Default 00)
12.3.3.6
TRUNK0_HASH1 - Trunk group 0 hash result 1 destination port number
CPU Address:h205 Accessed by CPU, serial interface (R/W) Bit [4:0] Hash result 1 destination port number (Default 01)
12.3.3.7
TRUNK0_HASH2 - Trunk group 0 hash result 2 destination port number
CPU Address:h206 Accessed by CPU, serial interface (R/W) Bit [4:0] Hash result 2 destination port number (Default 02)
12.3.3.8
TRUNK0_HASH3 - Trunk group 0 hash result 3 destination port number
CPU Address:h207 Accessed by CPU, serial interface (R/W) Bit [4:0] Hash result 3 destination port number (Default 03)
12.3.3.9
TRUNK1_L - Trunk group 1 Low (Managed mode only)
CPU Address:h208 Accessed by CPU, serial interface (R/W) Bit [7:0]: Port7-0 bit map of trunk 1. (Default 00)
87
Zarlink Semiconductor Inc.
ZL50416
12.3.3.10 TRUNK1_M - Trunk group 1 Medium (Managed mode only)
Data Sheet
CPU Address:h209 Accessed by CPU, serial interface (R/W) Bit [7:0]: Port15-8 bit map of trunk 1. (Default 00)
12.3.3.11
TRUNK1_H - Trunk group 1 High (Managed mode only)
CPU Address:h20A Accessed by CPU, serial interface (R/W) Bit [7:0]: Reserved (Default 00)
12.3.3.12
TRUNK1_MODE - Trunk group 1 mode
I2C Address h0A6; CPU Address:20B Accessed by CPU, serial interface and I2C (R/W) 7 2 1 0
Port Select Bit [1:0]: * Port selection in unmanaged mode. Input pin TRUNK1 enable/disable trunk group 1 in unmanaged mode.
* * * * 00 01 10 11 Reserved Port 4 and 5 are used for trunk1 Reserved Port 4,5,6 and 7 are used for trunk1
12.3.3.13
TRUNK1_HASH0 - Trunk group 1 hash result 0 destination port number
CPU Address:h20C Accessed by CPU, serial interface (R/W) Bit [4:0] Hash result 0 destination port number (Default 04)
12.3.3.14
TRUNK1_HASH1 - Trunk group 1 hash result 1 destination port number
CPU Address:h20D Accessed by CPU, serial interface (R/W) Bit [4:0] Hash result 1 destination port number (Default 05)
12.3.3.15
TRUNK1_HASH2 - Trunk group 1 hash result 2 destination port number
CPU Address:h20E Accessed by CPU, serial interface (R/W) Bit [4:0] Hash result 1 destination port number (Default 06)
88
Zarlink Semiconductor Inc.
ZL50416
12.3.3.16
Data Sheet
TRUNK1_HASH3 - Trunk group 1 hash result 3 destination port number
CPU Address:h20F Accessed by CPU, serial interface (R/W) Bit [4:0] Hash result 1 destination port number (Default 07)
12.3.3.17
TRUNK2_MODE - Trunk group 2 mode
CPU Address:210 Accessed by CPU, serial interface (R/W) Bit [:0] Reserved
12.3.3.18
TRUNK2_HASH0 - Trunk group 2 hash result 0 destination port number
CPU Address:h211 Accessed by CPU, serial interface (R/W) Bit [7:0] Reserved
12.3.3.19
TRUNK2_HASH1 - Trunk group 2 hash result 1 destination port number
CPU Address:h211 Accessed by CPU, serial interface (R/W) Bit [7:0] Reserved
Multicast Hash Registers
Multicast Hash registers are used to distribute multicast traffic. 16 registers are used to form a 4-entry array; each entry has 27 bits, with each bit representing one port. Any port not belonging to a trunk group should be programmed with 1. Ports belonging to the same trunk group should only have a single port set to "1" per entry. The port set to "1" is picked to transmit the multicast frame when the hash value is met. Hash Value =0 Hash Value =1 Hash Value =2 Hash Value =3 HASH0_3 HASH1_3 HASH2_3 HASH3_3 P o r t 2 4 (C P U) HASH0_2 HASH1_2 HASH2_2 HASH3_2 HASH0_1 HASH1_1 HASH2_1 HASH3_1 P o r t 1 5 P o r t 8 HASH0_0 HASH1_0 HASH2_0 HASH3_0 P o r t 7 P o r t 0
89
Zarlink Semiconductor Inc.
ZL50416
12.3.3.20 MULTICAST_HASHn_0 - Multicast hash result 0~3 mask byte 0
Data Sheet
CPU Address:h220+n (n=Hash Number) Accessed by CPU, serial interface (R/W) Bit [7:0] (Default FF)
12.3.3.21
MULTICAST_HASHn_1 - Multicast hash result 0~3 mask byte 1
CPU Address:h221+n (n=Hash Number) Accessed by CPU, serial interface (R/W) Bit [7:0] (Default FF)
12.3.3.22
MULTICAST_HASHn_2 - Multicast hash result 0~3 mask byte 2
CPU Address:h222+n (n=Hash Number) Accessed by CPU, serial interface (R/W) Bit [7:0] (Default FF)
12.3.3.23
MULTICAST_HASHn_3 - Multicast hash result 0~3 mask byte 3
CPU Address:h223+n (n=Hash Number) Accessed by CPU, serial interface (R/W) Bit [7:0] (Default FF)
12.3.4 12.3.4.1
(Group 3 Address) CPU Port Configuration Group MAC0 - CPU Mac address byte 0
MAC5 to MAC0 registers form the CPU MAC address. When a packet with destination MAC address match MAC [5:0], the packet is forwarded to the CPU. MAC5 CPU Address:h300 Accessed by CPU Bit [7:0] Byte 0 of the CPU MAC address. (Default 00) MAC4 MAC3 MAC2 MAC1 MAC0
12.3.4.2
MAC1 - CPU Mac address byte 1
CPU Address:h301 Accessed by CPU Bit [7:0] Byte 1 of the CPU MAC address. (Default 00)
12.3.4.3
MAC2 - CPU Mac address byte 2
CPU Address:h302 Accessed by CPU Bit [7:0] Byte 2 of the CPU MAC address. (Default 00)
90
Zarlink Semiconductor Inc.
ZL50416
12.3.4.4 MAC3 - CPU Mac address byte 3
Data Sheet
CPU Address:h303 Accessed by CPU Bit [7:0] Byte 3 of the CPU MAC address. (Default 00)
12.3.4.5
MAC4 - CPU Mac address byte 4
CPU Address:h304 Accessed by CPU Bit [7:0] Byte 4 of the CPU MAC address. (Default 00)
12.3.4.6
MAC5 - CPU Mac address byte 5
CPU Address:h305 Accessed by CPU Bit [7:0] Byte 5 of the CPU MAC address. (Default 00).
12.3.4.7
INT_MASK0 - Interrupt Mask 0
CPU Address:h306 Accessed by CPU, serial interface (R/W) The CPU can dynamically mask the interrupt when it is busy and doesn't want to be interrupted. (Default 0xFF) - 1: Mask the interrupt - 0: Unmask the interrupt (Enable interrupt) Bit [0]: Bit [1]: Bit [2]: Bit [7:3]: CPU frame interrupt. CPU frame buffer has data for CPU to read Control Command 1 interrupt. Control Command Frame buffer1 has data for CPU to read Control Command 2 interrupt. Control command Frame buffer2 has data for CPU to read Reserved
91
Zarlink Semiconductor Inc.
ZL50416
12.3.4.8 INTP_MASK0 - Interrupt Mask for MAC Port 0,1
Data Sheet
CPU Address:h310 Accessed by CPU, serial interface (R/W) The CPU can dynamically mask the interrupt when it is busy and doesn't want to be interrupted (Default 0xFF)
7
6
5 P1
4
3
2
1
0 P0
- 1: Mask the interrupt - 0: Unmask the interrupt Bit [0]: Port 0 statistic counter wrap around interrupt mask. An Interrupt is generated when a statistic counter wraps around. Refer to hardware statistic counter for interrupt sources. Port 0 link change mask Port 1 statistic counter wrap around interrupt mask. counter for interupt sources. Port 1 link change mask Refer to hardware statistic
Bit [1]: Bit [4]: Bit [5]:
12.3.4.9
INTP_MASKn - Interrupt Mask for MAC Ports
INTP_MASK1 CPU Address:h311 (Ports 2,3) INTP_MASK2 CPU Address:h312 (Ports 4,5) INTP_MASK3 CPU Address:h313 (Ports 6,7) INTP_MASK4 CPU Address:h314 (Ports 8,9) INTP_MASK5 CPU Address:h315 (Ports 10,11) INTP_MASK6 CPU Address:h316 (Ports 12,13) INTP_MASK7 CPU Address:h317 (Ports 14,15)
92
Zarlink Semiconductor Inc.
ZL50416
12.3.4.10 RQS - Receive Queue Select
Data Sheet
CPU Address:h323 Accessed by CPU, serial interface (RW) Select which receive queue is used. 7 FQ3 6 FQ2 5 FQ1 4 FQ0 3 SQ3 2 SQ2 1 SQ1 0 SQ0
Bit [0]:
Select Queue 0. If set to one this queue may be scheduled to CPU port. If set to zero, this queue will be blocked. If multiple queues are selected, a strict priority will be applied. Q3> Q2> Q1> Q0. Same applies to bits [3:1]. See QoS Application Note for more information. Select Queue 1 Select Queue 2 Select Queue 3
Bit [1]: Bit[2]: Bit [3]:
Note: Strip priority applies between different selected queues (Q3>Q2>Q1>Q0) Bit [4]: Bit [5]: Bit [6]: Bit [7]: Enable flush Queue 0 Enable flush Queue 1 Enable flush Queue 2 Enable flush Queue 3
When flush (drop frames) is enable, it starts when queue is too long or entry is too old. A queue is too long when it reaches WRED thresholds. Queue 0 is not subject to early drop. Packets in queue 0 are dropped only when the queue is too old. An entry is too old when it is older than the time programmed in the register TX_AGE [5:0]. CPU can dynamically program this register reading register RQSS [7:4].
12.3.4.11
RQSS - Receive Queue Status
CPU Address:h324 Accessed by CPU, serial interface (RO) 7 LQ3 6 LQ2 5 LQ1 4 LQ0 3 NeQ3 2 NeQ2 1 NeQ1 0 NeQ0
CPU receive queue status Bit [3:0]: Queue 3 to 0 not empty Bit [4]: Head of line entry for Queue 0 is valid for too long. CPU Queue 0 has no WRED threshold. Bit [7:5]: Head of line entry for Queue 3 to 1 is valid for too long or Queue length is longer than WRED threshold.
93
Zarlink Semiconductor Inc.
ZL50416
12.3.4.12 TX_AGE - Tx Queue Aging timer
Data Sheet
I2C Address: h07;CPU Address:h324 Accessed by CPU, serial interface (RW) 7 6 5 Tx Queue Agent Bit [5:0]: Unit of 100ms (Default 8) Disable transmission queue aging if value is zero. Aging timer for all ports and queues. This register must be set to 0 for `No Packet Loss Flow Control Test'. 0
12.3.5 12.3.5.1
(Group 4 Address) Search Engine Group AGETIME_LOW - MAC address aging time Low
I2C Address h0A8; CPU Address:h400 Accessed by CPU, serial interface and I2C (R/W) The ZL50416 removes the MAC address from the data base and sends a Delete MAC Address Control Command to the CPU. MAC address aging is enable/disable by boot strap TSTOUT9. Bit [7:0] Low byte of the MAC address aging timer.
12.3.5.2
AGETIME_HIGH -MAC address aging time High
I2C Address h0A9; CPU Address h401 Accessed by CPU, serial interface and I2C (R/W) Bit [7:0]: High byte of the MAC address aging timer. The default setting provide 300 seconds aging time. Aging time is based on the following equation: {AGETIME_TIME,AGETIME_LOW} X (# of MAC entries in the memory X100sec). Number of MAC entries = 32K when 1 MB is used per Bank. Number of entries = 64K when 2 MB is used per Bank.
12.3.5.3
V_AGETIME - VLAN to Port aging time
CPU Address h402 Accessed by CPU (R/W) Bit [7:0] (Default FF) V_AGETIME X 256 X 100 msec is the age time for the VLAN. This timer is for controlling how long a port is associated to a particular VLAN. It can use dynamic shrinking of a VLAN domain if no packet arrives for the VLAN. The ZL50416 does not remove the port from the VLAN domain. It sends an Age VLAN Port Control Command to the CPU. The CPU has to remove the port.
94
Zarlink Semiconductor Inc.
ZL50416
12.3.5.4 SE_OPMODE - Search Engine Operation Mode
Data Sheet
CPU Address:h403 Accessed by CPU (R/W) Note: ECR2[2] enable/disable learning for each port. 7 SL Bit [0]: 6 DMS 5 ARP 4 DRA 3 DA 2 DRD 1 DRN 0 FL
1 - Enable fast learning mode. In this mode, the hardware learns all the new MAC addresses at highest rate, and reports to the CPU while the hardware scans the MAC database. When the CPU report queue is full, the MAC address is learned and marked as "Not reported". When the hardware scans the database and finds a MAC address marked as "Not Reported" it tries to report it to the CPU. The scan rate must be set. SCAN Control register sets the scan rate. (Default 0) 0 - Search Engine learns a new MAC address and sends a message to the CPU report queue. If queue is full, the learning is temporarily halted.
Bit [1]:
1 - Disable report new VLAN port association(Default 0) 0 - Report new VLAN port association
Bit [2]:
Report control
* 1 - Disable report MAC address deletion (Default 0) * 0 - Report MAC address deletion (MAC address is deleted from MCT after aging time)
Bit [3]:
Delete Control
* 1 - Disable aging logic from removing MAC during aging (Default 0) * 0 - MAC address entry is removed when it is old enough to be aged.
However, a report is still sent to the CPU in both cases, when bit[2] = 0 Bit [4]: 1 - Disable report aging VLAN port association (Default 0) 0 - Enable Report aging VLAN. VLAN is not removed by hardware. The CPU needs to remove the VLAN -port association. Bit [5]: Bit [6]: 1 - Report ARP packet to CPU (Default 0) Disable MCT speedup aging (Default 0)
* 1 - Disable speedup aging when MCT resource is low. * 0 - Enable speedup aging when MCT resource is low.
Bit [7]:
Slow Learning (Default 0)
* 1- Enable slow learning. Learning is temporary disabled when search demand is high * 0 - Learning is performed independent of search demand
95
Zarlink Semiconductor Inc.
ZL50416
12.3.5.5 SCAN - SCAN Control Register (default 00)
Data Sheet
CPU Address h404 Accessed by CPU (R/W) 7 R 6 Ratio 0
SCAN is used when fast learning is enabled (SE_OPMODE bit 0). It is used for setting up the report rate for newly learned MAC addresses to the CPU. Bit [6:0]: Bit [7]: Examples: R= 0, Ratio = 0: R= 0, Ratio = 1: R= 1, Ratio = 7: R= 0, Ratio = 7: All rounds are used for aging. Never scan for new MAC addresses. Aging and scanning in every other aging round In eight rounds, one is used for scanning and seven are used for aging In eight rounds, one is used for aging and seven are used for scanning * * Ratio between database scanning and aging round (Default 00) Reverse the ratio between scanning round and aging round (Default 0)
12.3.6 12.3.6.1
(Group 5 Address) Buffer Control/QOS Group FCBAT - FCB Aging Timer
I2C Address h0AA; CPU Address:h500 Accessed by CPU, serial interface and I2C (R/W) 7 FCBAT Bit [7:0]: * * FCB Aging time. Unit of 1ms. (Default FF) This is for buffer aging control. It is used to configure the buffer aging time. This function can be enabled/disabled through bootstrap pin. It is not suggested to use this function for normal operation. 0
12.3.6.2
QOSC - QOS Control
I2C Address h0AB; CPU Address:h501 Accessed by CPU, serial interface and I2C (R/W) 7 Tos-d Bit [0]: 6 Tos-p * 5 PMCQ 4 VF1c 3 1 0 L
QoS frame lost is OK. Priority will be available for flow control enabled source only when this bit is set (Default 0)
96
Zarlink Semiconductor Inc.
ZL50416
Bit [4]: * Per VLAN Multicast Flow Control (Default 0)
* 0 - Disable * 1 - Enable
Data Sheet
Bit [5]:
*
Select processor multicast queue size
* 0 = 16 entries * 1 = 64 entries
Bit [6]:
*
Select TOS bits for Priority (Default 0)
* 0 - Use TOS [4:2] bits to map the transmit priority * 1 - Use TOS [7:5] bits to map the transmit priority
Bit [7]:
*
Select TOS bits for Drop priority(Default 0)
* 0 - Use TOS [4:2] bits to map the drop priority * 1 - Use TOS [7:5] bits to map the drop priority
12.3.6.3
FCR - Flooding Control Register
I2C Address h0AC; CPU Address:h502 Accessed by CPU, serial interface and I2C (R/W) 7 Tos Bit [3:0]: 6 TimeBase * 4 3 U2MR 0
U2MR: Unicast to Multicast Rate. Units in terms of time base defined in bits [6:4]. This is used to limit the amount of flooding traffic. The value in U2MR specifies how many packets are allowed to flood within the time specified by bit [6:4]. To disable this function, program U2MR to 0. (Default = 8)
Bit [6:4]:
Time Base: (Default = 000) 000 = 100 us 001 = 200 us 010 = 400 us 011 = 800 us 100 = 1.6 ms 101 = 3.2 ms 110 = 6.4 ms 111 = 100 us, same as 000.
Bit [7]:
Select VLAN tag or TOS (IP packets) to be preferentially picked to map transmit priority and drop priority (Default = 0). 0 - Select VLAN Tag priority field over TOS 1 - Select TOS over VLAN tag priority field
97
Zarlink Semiconductor Inc.
ZL50416
12.3.6.4 AVPML - VLAN Tag Priority Map
Data Sheet
I2C Address h0AD; CPU Address:h503 Accessed by CPU, serial interface and I2C (R/W) 7 6 VP2 5 VP1 3 2 VP0 0
Registers AVPML, AVPMM and AVPMH allow the eight VLAN Tag priorities to map into eight Internal level transmit priorities. Under the Internal transmit priority, seven is the highest priority where as zero is the lowest. This feature allows the user the flexibility of redefining the VLAN priority field. For example, programming a value of 7 into bit 2:0 of the AVPML register would map packet VLAN priority 0 into Internal transmit priority 7. The new priority is used inside the ZL50416. When the packet goes out it carries the original priority. Bit [2:0]: Bit [5:3]: Bit [7:6]: Priority when the VLAN tag priority field is 0 (Default 0) Priority when the VLAN tag priority field is 1 (Default 0) Priority when the VLAN tag priority field is 2 (Default 0)
12.3.6.5
AVPMM - VLAN Priority Map
I2C Address h0AE, CPU Address:h504 Accessed by CPU, serial interface and I2C (R/W) Map VLAN priority into eight level transmit priorities: 7 VP5 Bit [0]: Bit [3:1]: Bit [6:4]: Bit [7]: 6 VP4 4 3 VP3 1 0 VP2
Priority when the VLAN tag priority field is 2 (Default 0) Priority when the VLAN tag priority field is 3 (Default 0) Priority when the VLAN tag priority field is 4 (Default 0) Priority when the VLAN tag priority field is 5 (Default 0)
12.3.6.6
AVPMH - VLAN Priority Map
I2C Address h0AF, CPU Address:h505 Accessed by CPU, serial interface and I2C (R/W) 7 VP7 5 4 VP6 2 1 0 VP5
Map VLAN priority into eight level transmit priorities: Bit [1:0]: Bit [4:2]: Bit [7:5]: Priority when the VLAN tag priority field is 5 (Default 0) Priority when the VLAN tag priority field is 6 (Default 0) Priority when the VLAN tag priority field is 7 (Default 0)
98
Zarlink Semiconductor Inc.
ZL50416
12.3.6.7 TOSPML - TOS Priority Map
Data Sheet
I2C Address h0B0, CPU Address:h506 Accessed by CPU, serial interface and I2C (R/W) 7 TP2 6 5 TP1 3 2 TP0 0
Map TOS field in IP packet into eight level transmit priorities Bit [2:0]: Bit [5:3]: Bit [7:6]: Priority when the TOS field is 0 (Default 0) Priority when the TOS field is 1 (Default 0) Priority when the TOS field is 2 (Default 0)
12.3.6.8
TOSPMM - TOS Priority Map
I2C Address h0B1, CPU Address:h507 Accessed by CPU, serial interface and I2C (R/W) 7 TP5 6 TP4 4 3 TP3 0 TP2
1
Map TOS field in IP packet into eight level transmit priorities Bit [0]: Bit [3:1]: Bit [6:4]: Bit [7]: Priority when the TOS field is 2 (Default 0) Priority when the TOS field is 3 (Default 0) Priority when the TOS field is 4 (Default 0) Priority when the TOS field is 5 (Default 0)
12.3.6.9
TOSPMH - TOS Priority Map
I2C Address h0B2, CPU Address:h508 Accessed by CPU, serial interface and I2C (R/W) 7 TP7 5 4 TP6 2 1 0 TP5
Map TOS field in IP packet into eight level transmit priorities: Bit [1:0]: Bit [4:2]: Bit [7:5]: Priority when the TOS field is 5 (Default 0) Priority when the TOS field is 6 (Default 0) Priority when the TOS field is 7 (Default 0)
12.3.6.10
AVDM - VLAN Discard Map
I2C Address h0B3, CPU Address:h509 Accessed by CPU, serial interface and I2C (R/W)
99
Zarlink Semiconductor Inc.
ZL50416
7 FDV7 6 FDV6 5 FDV5 4 FDV4 3 FDV3 2 FDV2 1 FDV1 0 FDV0
Data Sheet
Map VLAN priority into frame discard when low priority buffer usage is above threshold Bit [0]: Bit [1]: Bit [2]: Bit [3]: Bit [4]: Bit [5]: Bit [6]: Bit [7]: Frame drop priority when VLAN Tag priority field is 0 (Default 0) Frame drop priority when VLAN Tag priority field is 1 (Default 0) Frame drop priority when VLAN Tag priority field is 2 (Default 0) Frame drop priority when VLAN Tag priority field is 3 (Default 0) Frame drop priority when VLAN Tag priority field is 4 (Default 0) Frame drop priority when VLAN Tag priority field is 5 (Default 0) Frame drop priority when VLAN Tag priority field is 6 (Default 0) Frame drop priority when VLAN Tag priority field is 7 (Default 0)
12.3.6.11
TOSDML - TOS Discard Map
I2C Address h0B4, CPU Address:h50A Accessed by CPU, serial interface and I2C (R/W) 7 FDT7 6 FDT6 5 FDT5 4 FDT4 3 FDT3 2 FDT2 1 FDT1 0 FDT0
Map TOS into frame discard when low priority buffer usage is above threshold Bit [0]: Bit [1]: Bit [2]: Bit [3]: Bit [4]: Bit [5]: Bit [6]: Bit [7]: Frame drop priority when TOS field is 0 (Default 0) Frame drop priority when TOS field is 1 (Default 0) Frame drop priority when TOS field is 2 (Default 0) Frame drop priority when TOS field is 3 (Default 0) Frame drop priority when TOS field is 4 (Default 0) Frame drop priority when TOS field is 5 (Default 0) Frame drop priority when TOS field is 6 (Default 0) Frame drop priority when TOS field is 7 (Default 0)
12.3.6.12
BMRC - Broadcast/Multicast Rate Control
I2C Address h0B5, CPU Address:h50B) Accessed by CPU, serial interface and I2C (R/W) 7 Broadcast Rate 4 3 Multicast Rate 0
100
Zarlink Semiconductor Inc.
ZL50416
Data Sheet
This broadcast and multicast rate defines for each port, the number of packets allowed to be forwarded within a specified time. Once the packet rate is reached, packets will be dropped. To turn off the rate limit, program the field to 0. Time base is based on register FCR [6:4] Bit [3:0] : Multicast Rate Control. Number of multicast packets allowed within the time defined in bits 6 to 4 of the Flooding Control Register (FCR). (Default 0). Broadcast Rate Control. Number of broadcast packets allowed within the time defined in bits 6 to 4 of the Flooding Control Register (FCR). (Default 0)
Bit [7:4] :
12.3.6.13
UCC - Unicast Congestion Control
I2C Address h0B6, CPU Address: 50C Accessed by CPU, serial interface and I2C (R/W) 7 Unicast congest threshold Bit [7:0] : Number of frame count. Used for best effort dropping at B% when destination port's best effort queue reaches UCC threshold and shared pool is all in use. Granularity 1 frame. (Default: h10 for 2 MB/bank or h08 for 1 MB/bank) 0
12.3.6.14
MCC - Multicast Congestion Control
I2C Address h0B7, CPU Address: 50D Accessed by CPU, serial interface and I2C (R/W) 7 5 4 Multicast congest threshold 0
FC reaction period Bit [4:0]:
In multiples of two frames (granularity). Used for triggering MC flow control when destination port's multicast best effort queue reaches MCC threshold.(Default 0x10) Flow control reaction period (Default 2) Granularity 4uSec.
Bit [7:5]:
12.3.6.15
PR100 - Port Reservation for 10/100 ports
I2C Address h0B8, CPU Address 50E Accessed by CPU, serial interface and I2C (R/W) 7 Buffer low threshold Bit [3:0]: 4 3 0
SP Buffer reservation
Per source port buffer reservation. Define the space in the FDB reserved for each 10/100 port and CPU. Expressed in multiples of 4 packets. For each packet 1536 bytes are reserved in the memory.
101
Zarlink Semiconductor Inc.
ZL50416
Bits [7:4]:
Data Sheet
Expressed in multiples of 4 packets. Threshold for dropping all best effort frames when destination port best efforts queues reaches UCC threshold, shared pool is all used and source port reservation is at or below the PR100[7:4] level. Also the threshold for initiating UC flow control. * Default: - h36 for 24+2 configuration with memory 2 MB/bank; - h24 for 24+2 configuration with 1MB/bank;
12.3.6.16
SFCB - Share FCB Size
I2C Address h0BA), CPU Address 510 Accessed by CPU, serial interface and I2C (R/W) 7 Shared pool buffer size Bits [7:0]: Expressed in multiples of 4 packets. Buffer reservation for shared pool. * Default: - h64 for 24+2 configuration with memory of 2 MB/bank; - h14 for 24+2 configuration with memory of 1 MB/bank; 0
12.3.6.17
C2RS - Class 2 Reserve Size
I2C Address h0BB, CPU Address 511 Accessed by CPU, serial interface and I2C (R/W) 7 Class 2 FCB Reservation Buffer reservation for class 2 (third lowest priority). Granularity 1. (Default 0) 0
12.3.6.18
C3RS - Class 3 Reserve Size
I2C Address h0BC, CPU Address 512 Accessed by CPU, serial interface and I2C (R/W) 7 Class 3 FCB Reservation Buffer reservation for class 3. Granularity 1. (Default 0) 0
102
Zarlink Semiconductor Inc.
ZL50416
12.3.6.19 C4RS - Class 4 Reserve Size
Data Sheet
I2C Address h0BD, CPU Address 513 Accessed by CPU, serial interface and I2C (R/W) 7 Class 4 FCB Reservation Buffer reservation for class 4. Granularity 1. (Default 0) 0
12.3.6.20
C5RS - Class 5 Reserve Size
I2C Address h0BE; CPU Address 514 Accessed by CPU, serial interface and I2C (R/W) 7 Class 5 FCB Reservation Buffer reservation for class 5. Granularity 1. (Default 0) 0
12.3.6.21
C6RS - Class 6 Reserve Size
I2C Address h0BF; CPU Address 515 Accessed by CPU, serial interface and I2C (R/W) 7 Class 6 FCB Reservation Buffer reservation for class 6 (second highest priority). Granularity 1. (Default 0) 0
12.3.6.22
C7RS - Class 7 Reserve Size
I2C Address h0C0; CPU Address 516 Accessed by CPU, serial interface and I2C (R/W) 7 Class 7 FCB Reservation Buffer reservation for class 7 (highest priority). Granularity 1. (Default 0) 0
12.3.6.23
QOSC00~02 - Classes Byte Limit Set 0
Accessed by CPU; serial interface and I2C (R/W): C -- QOSC00 - BYTE_C01 (I2C Address h0C1, CPU Address 517) B -- QOSC01 - BYTE_C02 (I2C Address h0C2, CPU Address 518) A -- QOSC02 - BYTE_C03 (I2C Address h0C3, CPU Address 519) QOSC00 through QOSC02 represents one set of values A-C for a 10/100 port when using the Weighted Random Early Drop (WRED) Scheme described in Chapter 7. There are four such sets of values A-C specified in Classes Byte Limit Set 0, 1, 2, and 3. For CPU port A-C values are defined using register CPUQOSC1, 2 and 3.
103
Zarlink Semiconductor Inc.
ZL50416
Data Sheet
Each 10/ 100 port can choose one of the four Byte Limit Sets as specified by the QoS Select field located in bits 5 to 4 of the ECR2n register. The values A-C are per-queue byte thresholds for random early drop. QOSC02 represents A, and QOSC00 represents C. Granularity when Delay bound is used: QOSC02: 128 bytes, QOSC01: 256 bytes, QOSC00: 512 bytes. Granularity when WFQ is used: QOSC02: 512 bytes, QOSC01: 512 bytes, QOSC00: 512 bytes.
12.3.6.24
QOSC03~05 - Classes Byte Limit Set 1
Accessed by CPU, serial interface and I2C (R/W): C - QOSC03 - BYTE_C11 (I2C Address h0C4, CPU Address 51a) B - QOSC04 - BYTE_C12 (I2C Address h0C5, CPU Address 51b) A - QOSC05 - BYTE_C13 (I2C Address h0C6, CPU Address 51c) QOSC03 through QOSC05 represents one set of values A-C for a 10/100 port when using the Weighted Random Early Drop (WRED) scheme. Granularity when Delay bound is used: QOSC05: 128 bytes, QOSC04: 256 bytes, QOSC03: 512 bytes. Granularity when WFQ is used: QOSC05: 512 bytes, QOSC04: 512 bytes, QOSC03: 512 bytes.
12.3.6.25
QOSC06~08 - Classes Byte Limit Set 2
Accessed by CPU and serial interface (R/W): C - QOSC06 - BYTE_C21 (CPU Address 51d) B - QOSC07 - BYTE_C22 (CPU Address 51e) A - QOSC08 - BYTE_C23 (CPU Address 51f) QOSC06 through QOSC08 represents one set of values A-C for a 10/100 port when using the Weighted Random Early Drop (WRED) scheme. Granularity when Delay bound is used: QOSC08: 128 bytes, QOSC07: 256 bytes, QOSC06: 512 bytes. Granularity when WFQ is used: QOSC08: 512 bytes, QOSC07: 512 bytes, QOSC06: 512 bytes
12.3.6.26
QOSC09~11 - Classes Byte Limit Set 3
Accessed by CPU and serial interface (R/W): C - QOSC09 - BYTE_C31 (CPU Address 520) B - QOSC10 - BYTE_C32 (CPU Address 521) A - QOSC11 - BYTE_C33 (CPU Address 522) QOSC09 through QOSC011 represents one set of values A-C for a 10/100 port when using the Weighted Random Early Drop (WRED) scheme. Granularity when Delay bound is used: QOSC11: 128 bytes, QOSC10: 256 bytes, QOSC09: 512 bytes. Granularity when WFQ is used: QOSC11: 512 bytes, QOSC10: 512 bytes, QOSC09: 512 bytes
104
Zarlink Semiconductor Inc.
ZL50416
12.3.6.27 QOSC24~27 - Classes WFQ Credit Set 0
Data Sheet
Accessed by CPU and serial interface W0 - QOSC24[5:0] - CREDIT_C00 (CPU Address 52f) W1 - QOSC25[5:0] - CREDIT_C01 (CPU Address 530) W2 - QOSC26[5:0] - CREDIT_C02 (CPU Address 531) W3 - QOSC27[5:0] - CREDIT_C03 (CPU Address 532) QOSC24 through QOSC27 represents one set of WFQ parameters for a 10/100 port. There are four such sets of values. The granularity of the numbers is 1, and their sum must be 64. QOSC27 corresponds to W3 and QOSC24 corresponds to W0. QOSC24[7:6]: Priority service type for the ports select this parameter set. Option 1 to option 4. QOSC25[7]: Priority service allow flow control for the ports select this parameter set. QOSC25[6]: Flow control pause best effort traffic only Both flow control allow and flow control best effort only can take effect only the priority type is WFQ.
12.3.6.28
QOSC28~31 - Classes WFQ Credit Set 1
Accessed by CPU and serial interface W0 - QOSC28[5:0] - CREDIT_C10 (CPU Address 533) W1 - QOSC29[5:0] - CREDIT_C11 (CPU Address 534) W2 - QOSC30[5:0] - CREDIT_C12 (CPU Address 535) W3 - QOSC31[5:0] - CREDIT_C13 (CPU Address 536) QOSC28 through QOSC31 represents one set of WFQ parameters for a 10/100 port. There are four such sets of values. The granularity of the numbers is 1, and their sum must be 64. QOSC31 corresponds to W3 and QOSC28 corresponds to W0. QOSC28[7:6]: Priority service type for the ports select this parameter set. Option 1 to option 4. QOSC29[7]: Priority service allow flow control for the ports select this parameter set. QOSC29[6]: Flow control pause best effort traffic only
12.3.6.29
QOSC32~35 - Classes WFQ Credit Set 2
Accessed by CPU and serial interface W0 - QOSC32[5:0] - CREDIT_C20 (CPU Address 537) W1 - QOSC33[5:0] - CREDIT_C21 (CPU Address 538) W2 - QOSC34[5:0] - CREDIT_C22 (CPU Address 539) W3 - QOSC35[5:0] - CREDIT_C23 (CPU Address 53a) QOSC35 through QOSC32 represents one set of WFQ parameters for a 10/100 port. There are four such sets of values. The granularity of the numbers is 1 and their sum must be 64. QOSC35 corresponds to W3 and QOSC32 corresponds to W0. QOSC32[7:6]: Priority service type for the ports select this parameter set. Option 1 to option 4. QOSC33[7]: Priority service allow flow control for the ports select this parameter set. QOSC33[6]: Flow control pause for best effort traffic only
105
Zarlink Semiconductor Inc.
ZL50416
12.3.6.30 QOSC36~39 - Classes WFQ Credit Set 3
Data Sheet
Accessed by CPU and serial interface W0 - QOSC36[5:0] - CREDIT_C30 (CPU Address 53b) W1 - QOSC37[5:0] - CREDIT_C31 (CPU Address 53c) W2 - QOSC38[5:0] - CREDIT_C32 (CPU Address 53d) W3 - QOSC39[5:0] - CREDIT_C33 (CPU Address 53e) QOSC39 through QOSC36 represents one set of WFQ parameters for a 10/100 port. There are four such sets of values. The granularity of the numbers is 1 and their sum must be 64. QOSC39 corresponds to W0 and QOSC36 corresponds to W0. QOSC36[7:6]: Priority service type for the ports select this parameter set. Option 1 to option 4. QOSC37[7]: Priority service allow flow control for the ports select this parameter set. QOSC37[6]: Flow control pause best effort traffic only
12.3.6.31
RDRC0 - WRED Rate Control 0
I2C Address 0FB, CPU Address 553 Accessed by CPU, Serial Interface and IcC (R/W) 7 X Rate Bits [7:4]: Bits [3:0]: 4 3 Y Rate Corresponds to the frame drop percentage X% for WRED. Granularity 6.25%. Corresponds to the frame drop percentage Y% for WRED. Granularity 6.25%. 0
See Programming QoS Registers application note for more information
12.3.6.32
RDRC1 - WRED Rate Control 1
I2C Address 0FC, CPU Address 554 Accessed by CPU, Serial Interface and I2C (R/W) 7 Z Rate Bits [7:4]: Bits [3:0]: 4 3 B Rate Corresponds to the frame drop percentage Z% for WRED. Granularity 6.25%. Corresponds to the best effort frame drop percentage B%, when shared pool is all in use and destination port best effort queue reaches UCC. Granularity 6.25%. 0
See Programming QoS Registers application note for more information
106
Zarlink Semiconductor Inc.
ZL50416 User Defined Logical Ports and Well Known Ports
Data Sheet
The ZL50416 supports classifying packet priority through layer 4 logical port information. It can be setup by 8 Well Known Ports, 8 User Defined Logical Ports, and 1 User Defined Range. The 8 Well Known Ports supported are: * * * * * * * * 23 512 6000 443 111 22555 22 554
Their respective priority can be programmed via Well_Known_Port [7:0] priority register. Well_Known_Port_Enable can individually turn on/off each Well Known Port if desired. Similarly, the User Defined Logical Port provides the user programmability to the priority, plus the flexibility to select specific logical ports to fit the applications. The 8 User Logical Ports can be programmed via User_Port 0-7 registers. Two registers are required to be programmed for the logical port number. The respective priority can be programmed to the User_Port [7:0] priority register. The port priority can be individually enabled/disabled via User_Port_Enable register. The User Defined Range provides a range of logical port numbers with the same priority level. Programming is similar to the User Defined Logical Port. Instead of programming a fixed port number, an upper and lower limit need to be programmed, they are: {RHIGHH, RHIGHL} and {RLOWH, RLOWL} respectively. If the value in the upper limit is smaller or equal to the lower limit, the function is disabled. Any IP packet with a logical port that is less than the upper limit and more than the lower limit will use the priority specified in RPRIORITY.
12.3.6.33
USER_PORT0~7)_L/H - USER DEFINE LOGICAL PORT (0~7)
USER_PORT0_L/H - I2C Address h0D6 + 0DE; CPU Address 580(Low) + 581(high) USER_PORT1_L/H - I2C Address h0D7 + 0DF; CPU Address 582 + 583 USER_PORT2_L/H - I2C Address h0D8 + 0E0; CPU Address 584 + 585 USER_PORT3_L/H - I2C Address h0D9 + 0E1; CPU Address 586 + 587 USER_PORT4_L/H - I2C Address h0DA + 0E2; CPU Address 588 + 589 USER_PORT5_L/H - I2C Address h0DB + 0E3; CPU Address 58A + 58B USER_PORT6_L/H - I2C Address h0DC + 0E4; CPU Address 58C + 58D USER_PORT7_L/H - I2C Address h0DD + 0E5; CPU Address 58E + 58F Accessed by CPU, serial interface and I2C (R/W) 7 TCP/UDP Logic Port Low 7 TCP/UDP Logic Port High (Default 00) This register is duplicated eight times from PORT 0 through PORT 7 and allows the CPU to define eight separate ports. 0 0
107
Zarlink Semiconductor Inc.
ZL50416
12.3.6.34 USER_PORT_[1:0]_PRIORITY - User Define Logic Port 1 and 0 Priority
Data Sheet
I2C Address h0E6, CPU Address 590 Accessed by CPU, serial interface and I2C (R/W) 7 Priority 1 5 4 Drop 3 Priority 0 1 0 Drop
The chip allows the CPU to define the priority Bits [3:0]: Bits [7:4]: Priority setting, transmission + dropping, for logic port 0 Priority setting, transmission + dropping, for logic port 1 (Default 00)
12.3.6.35
USER_PORT_[3:2]_PRIORITY - User Define Logic Port 3 and 2 Priority
I2C Address h0E7, CPU Address 591 Accessed by CPU, serial interface and I2C (R/W) 7 Priority 3 5 4 Drop 3 Priority 2 1 0 Drop
12.3.6.36
USER_PORT_[5:4]_PRIORITY - User Define Logic Port 5 and 4 Priority
I2C Address h0E8, CPU Address 592 Accessed by CPU, serial interface and I2C (R/W) 7 Priority 5 (Default 00) 5 4 Drop 3 Priority 4 1 0 Drop
12.3.6.37
USER_PORT_[7:6]_PRIORITY - USER DEFINE LOGIC PORT 7
AND
6 PRIORITY
I2C Address h0E9, CPU Address 593 Accessed by CPU, serial interface and I2C (R/W) 7 Priority 7 (Default 00) 5 4 Drop 3 Priority 6 1 0 Drop
12.3.6.38
USER_PORT_ENABLE[7:0] - User Define Logic 7 to 0 Port Enables
I2C Address h0EA, CPU Address 594 Accessed by CPU, serial interface and I2C (R/W) 7 P7 (Default 00) 6 P6 5 P5 4 P4 3 P3 2 P2 1 P1 0 P0
108
Zarlink Semiconductor Inc.
ZL50416
12.3.6.39
Data Sheet
WELL_KNOWN_PORT[1:0]_PRIORITY- Well Known Logic Port 1 and 0 Priority
I2C Address h0EB, CPU Address 595 Accessed by CPU, serial interface and I2C (R/W) 7 Priority 1 5 4 Drop 3 Priority 0 1 0 Drop
Priority 0 - Well known port 23 for telnet applications. Priority 1 - Well Known port 512 for TCP/UDP. (Default 00)
12.3.6.40
WELL_KNOWN_PORT[3:2]_PRIORITY- Well Known Logic Port 3 and 2 Priority
I2C Address h0EC, CPU Address 596 Accessed by CPU, serial interface and I2C (R/W) 7 Priority 3 5 4 Drop 3 Priority 2 1 0 Drop
Priority 2 - Well known port 6000 for XWIN. Priority 3 - Well known port 443 for http.sec (Default 00)
12.3.6.41
WELL_KNOWN_PORT [5:4]_PRIORITY- Well Known Logic Port 5 and 4 Priority
I2C Address h0ED, CPU Address 597 Accessed by CPU, serial interface and I2C (R/W) 7 Priority 5 5 4 Drop 3 Priority 4 1 0 Drop
Priority 4 - Well Known port 111 for sun remote procedure call. Priority 5 - Well Known port 22555 for IP Phone call setup. (Default 00)
12.3.6.42
WELL_KNOWN_PORT [7:6]_PRIORITY- WELL KNOWN LOGIC PORT 7
AND
6 PRIORITY
I2C Address h0EE, CPU Address 598 Accessed by CPU, serial interface and I2C (R/W) 7 Priority 7 5 4 Drop 3 Priority 6 1 0 Drop
Priority 6 - well know port 22 for ssh. Priority 7 - well Known port 554 for rtsp. (Default 00)
109
Zarlink Semiconductor Inc.
ZL50416
12.3.6.43
Data Sheet
WELL KNOWN_PORT_ENABLE [7:0] - Well Known Logic 7 to 0 Port Enables
I2C Address h0EF, CPU Address 599 Accessed by CPU, serial interface and I2C (R/W) 7 P7 1 - Enable 0 - Disable (Default 00) 6 P6 5 P5 4 P4 3 P3 2 P2 1 P1 0 P0
12.3.6.44
RLOWL - USER DEFINE RANGE LOW BIT 7:0
I2C Address h0F4, CPU Address: 59a Accessed by CPU, serial interface and I2C (R/W) [7:0] Lower 8 bit of the User Define Logical Port Low Range (Default 00)
12.3.6.45
RLOWH - User Define Range Low Bit 15:8
I2C Address h0F5, CPU Address: 59b Accessed by CPU, serial interface and I2C (R/W) [7:0] Upper 8 bit of the User Define Logical Port Low Range (Default 00)
12.3.6.46
RHIGHL - User Define Range High Bit 7:0
I2C Address h0D3, CPU Address: 59c Accessed by CPU, serial interface and I2C (R/W) [7:0] Lower 8 bit of the User Define Logical Port High Range (Default 00)
12.3.6.47
RHIGHH - User Define Range High Bit 15:8
I2C Address h0D4, CPU Address: 59d Accessed by CPU, serial interface and I2C (R/W) [7:0] Upper 8 bit of the User Define Logical Port High Range (Default 00)
12.3.6.48
RPRIORITY - User Define Range Priority
I2C Address h0D5, CPU Address: 59e Accessed by CPU, serial interface and I2C (R/W) 7 4 3 Range Transmit Priority 0 Drop
RLOW and RHIGH form a range for logical ports to be classified with priority specified in RPRIORITY. Bit[3:1] Bits[0]: Transmit Priority Drop Priority
110
Zarlink Semiconductor Inc.
ZL50416
12.3.6.49 CPUQOSC1,2,3
Data Sheet
CPU Address: 5a0, 5a1, 5a2 Accessed by CPU and serial interface (R/W) C - CPUQOSC1 - CPU BYTE_C1 (CPU Address 5A0) B - CPUQOSC2 - CPU BYTE_C2 (CPU Address 5A1) A - CPUQOSC3 - CPU BYTE_C3 (CPU Address 5A2) Represents values A-C for a CPU port. The values A-C are per-queue byte thresholds for random early drop. QOSC3 represents A, and QOSC1 represents C. Granularity: 256 bytes
12.3.7 12.3.7.1
(Group 6 Address) MISC Group MII_OP0 - MII Register Option 0
I2C Address F0, CPU Address:h600 Accessed by CPU, serial interface and I2C (R/W) 7 hfc Bits [7]: 6 1prst 5 DisJ 4 Vendor Spc. Reg Addr 0
Half duplex flow control feature 0 = Half duplex flow control always enable 1 = Half duplex flow control by negotiation
Bits [6]: Bits [5]:
Link partner reset auto-negotiate disable Disable jabber detection. This is for HomePNA applications or any serial operation slower than 10 Mbps. 0 = Enable 1 = Disable
Bit [4:0]:
Vendor specified link status register address (null value means don't use it) (Default 00). This is used if the Linkup bit position in the PHY is nonstandard.
12.3.7.2
MII_OP1 - MII Register Option 1
I2C Address F1, CPU Address:h601 Accessed by CPU, serial interface and I2C (R/W) 7 Speed bit location Bits [3:0]: Bits [7:4]: 4 3 Duplex bit location 0
Duplex bit location in vendor specified register Speed bit location in vendor specified register (Default 00)
111
Zarlink Semiconductor Inc.
ZL50416
12.3.7.3 FEN - Feature Register
Data Sheet
I2C Address F2, CPU Address:h602 Accessed by CPU, serial interface and I2C (R/W) 7 DML Bits [0]: 6 Mii 5 Rp 4 IP Mul 3 V-Sp 2 DS 1 RC 0 SC
Statistic Counter Enable (Default 0) * * 0 - Disable 1 - Enable (all ports)
When statistic counter is enable, an interrupt control frame is generated to the CPU, every time a counter wraps around. This feature requires an external CPU. Bits [1]: Rate Control Enable (Default 0) * * 0 - Disable 1 - Enable; Must also set ECR2Pn[3] = 1
This bit enables/disables the rate control for all 10/100 ports. To start rate control in a 10/100 port the rate control memory must be programmed. This feature requires an external CPU. See Programming QoS Registers Application Note and Processor Interface Application Note for more information. Bit [2]: Support DS EF Code. (Default 0) * * 0 - Disable 1 - Enable (all ports)
When 101110 is detected in DS field (TOS[7:2]), the frame priority is set for 110 and drop is set for 0. Bit [3]: Enable VLAN spanning tree support (Default 0) * * 0 - Disable 1 - Enable
When VLAN spanning tree is enable the registers ECR1Pn are NOT used to program the port spanning tree status. The port status is programmed using the Control Command Frame. Bit [4]: Disable IP Multicast Support (Default 1) * * 0 - Enable IP Multicast Support 1 - Disable IP Multicast Support
When enable, IGMP packets are identified by search engine and are passed to the CPU for processing. IP multicast packets are forwarded to the IP multicast group members according to the VLAN port mapping table.
112
Zarlink Semiconductor Inc.
ZL50416
Bit [5]: Enable report to CPU(Default 0) * * 0 - Disable report to CPU 1 - Enable report to CPU
Data Sheet
When disable new VLAN port association report, new MAC address report or aging reports are disable for all ports. When enable, register SE_OPEMODE is used to enable/disable selectively each function. Bit [6]: Disable MII Management State Machine (Default 0) * * Bit [7]: 0: Enable MII Management State Machine 1: Disable MII Management State Machine
Disable using MCT Link List structure (Default 0) 0 - Enable using MCT Link structure 1 - Disable using MCT Link List structure
12.3.7.4
MIIC0 - MII Command Register 0
CPU Address:h603 Accessed by CPU and serial interface only (R/W) Bit [7:0] - MII Data [7:0] Note: Before programming MII command: set FEN[6], check MIIC3, making sure no RDY, and no VALID; then program MII command.
12.3.7.5
MIIC1 - MII Command Register 1
CPU Address:h604 Accessed by CPU and serial interface only (R/W) Bit [7:0] - MII Data [15:8] Note: Before programming MII command: set FEN[6], check MIIC3, making sure no RDY and no VALID; then program MII command.
12.3.7.6
MIIC2 - MII Command Register 2
CPU Address:h605 Accessed by CPU and serial interface only (R/W) 7 6 Mii OP Bit [4:0] Bit [6:5] 5 4 Register address 0
REG_AD - Register PHY Address OP - Operation code "10" for read command and "01" for write command
Note: Before programming MII command: set FEN[6], check MIIC3, making sure no RDY and no VALID; then program MII command.
113
Zarlink Semiconductor Inc.
ZL50416
12.3.7.7 MIIC3 - MII Command Register 3
Data Sheet
CPU Address:h606 Accessed by CPU and serial interface only (R/W) 7 Rdy Bits [4:0] Bit [6] Bit [7] 6 Valid 5 4 PHY address 0
PHY_AD - 5 Bit PHY Address VALID - Data Valid from PHY (Read Only) RDY - Data is returned from PHY (Ready Only)
Note: Before programming MII command: set FEN[6], check MIIC3, making sure no RDY and no VALID; then program MII command. Writing this register will initiate a serial management cycle to the MII management interface.
12.3.7.8
MIID0 - MII Data Register 0
CPU Address:h607 Accessed by CPU and serial interface only (RO) Bit [7:0] - MII Data [7:0]
12.3.7.9
MIID1 - MII Data Register 1
CPU Address:h608 Accessed by CPU and serial interface only (RO) Bit [7:0] - MII Data [15:8]
12.3.7.10
LED Mode - LED Control
CPU Address:h609 Accessed by CPU, serial interface and I2C (R/W) 7 5 4 3 2 Hold Time 1 0
Clock rate Bit [0] Bit [2:1]: Reserved(Default 0)
Hold time for LED signal (Default 00) 00=8 msec 10=32 msec 01=16 msec 11=64 msec
Bit [4:3]:
LED clock frequency (Default 0) For 100MHz SCLK 00 = 100MHz/8 = 12.5 MHz 01 = 100MHz/16 = 6.25 MHz 10 = 100MHz/32 = 3.125 MHz 11 = 100MHz/64 = 1.5625 MHz For 125 MHz SCLK 00 = 125MHz/64 = 1953 KHz 01 = 125MHz/128 = 977 KHz 10 = 125MHz/512 = 244 KHz 11 = 125MHz/1024 = 122 KHz
Bit [7:5]:
Reserved. Must be set to `0' (Default 0)
114
Zarlink Semiconductor Inc.
ZL50416
12.3.7.11 DEVICE Mode
Data Sheet
CPU Address:h60a Accessed by CPU and serial interface (R/W) 7 Device ID Bit [1:0]: Bit [2]: 4 3 2 LgFrm 1 0
Reserved. Must be set to `0' (Default 0) Support < = 1536 frames 0: < = 1518 bytes (< = 1522 bytes with VLAN tag) (Default) 1: < = 1536 bytes
Bit [3]: Bit [7:4]:
Reserved. Must be set to `0' (Default 0) DEVICE ID (Default 0). This is for stacking operation. This is the stack ID for loop topology.
12.3.7.12
CHECKSUM - EEPROM Checksum
I2C Address FF, CPU Address:h60b Accessed by CPU, serial interface and I2C (R/W) Bit [7:0]: (Default 0)
This register is used in unmanaged mode only. Before requesting that the ZL50416 updates the EEPROM device, the correct checksum needs to be calculated and written into this checksum register. The checksum formula is:
FF
i2C register = 0
i=0
When the ZL50416 boots from the EEPROM the checksum is calculated and the value must be zero. If the checksum is not zeroed the ZL50416 does not start and pin CHECKSUM_OK is set to zero.
12.3.8 12.3.8.1
(Group 7 Address) Port Mirroring Group MIRROR1_SRC - Port Mirror source port
CPU Address 700 Accessed by CPU and serial interface (R/W) (Default 7F) 7 6 5 I/O Bit [4:0]: Bit [5]: 4 Src Port Select 0
Source port to be mirrored. Use illegal port number to disable mirroring 0 - select ingress data 1 - select egress data
115
Zarlink Semiconductor Inc.
ZL50416
Bit [6] Bit [7] Reserved Reserved must be set to '1'
Data Sheet
12.3.8.2
MIRROR1_DEST - Port Mirror destination
CPU Address 701 Accessed by CPU, serial interface (R/W) (Default 17) 7 5 4 Dest Port Select Bit [4:0]: Port Mirror Destination When port mirroring is enable, destination port can not serve as a data port. 0
12.3.8.3
MIRROR2_SRC - Port Mirror source port
CPU Address 702 Accessed by CPU, serial interface (R/W) (Default FF) 7 6 5 I/O Bit [4:0]: Bit [5]: 4 Src Port Select 0
Source port to be mirrored. Use illegal port number to disable mirroring 0 - select ingress data 1 - select egress data
Bit [6] Bit [7]
Reserved Reserved must be set to '1'
12.3.8.4
MIRROR2_DEST - Port Mirror destination
CPU Address 703 Accessed by CPU, serial interface (R/W) (Default 00) 7 5 4 Dest Port Select Bit [4:0]: Port Mirror Destination When port mirroring is enable, destination port can not serve as a data port. 0
116
Zarlink Semiconductor Inc.
ZL50416
12.3.9 12.3.9.1 (Group F Address) CPU Access Group GCR-Global Control Register
Data Sheet
CPU Address: hF00 Accessed by CPU and serial interface. (R/W) 7 5 4 Init Bit [0]: 3 Reset 2 Bist 1 SR 0 SC
Store configuration (Default = 0) Write `1' followed by `0' to store configuration into external EEPROM
Bit [1]:
Store configuration and reset (Default = 0) Write `1' to store configuration into external EEPROM and reset chip
Bit [2]:
Start BIST (Default = 0) Write `1' followed by `0' to start the device's built-in self-test. The result is found in the DCR register.
Bit [3]:
Soft Reset (Default = 0) Write `1' to reset chip
Bit [4]:
Initialization Done (Default = 0). This bit is meaningless in unmanaged mode. In managed mode, CPU write this bit with `1' to indicate initialization is completed and ready to forward packets. 1 = Initialization is done. 0 = Initialization is not complete.
117
Zarlink Semiconductor Inc.
ZL50416
12.3.9.2 DCR - Device Status and Signature Register
Data Sheet
CPU Address: hF01 Accessed by CPU and serial interface. (RO) 7 6 5 Signature 4 3 RE 2 BinP 1 BR 0 BW
Revision Bit [0]:
1: Busy writing configuration to I2C 0: Not busy (not writing configuration to I2C)
Bit [1]:
1: Busy reading configuration from I2C 0: Not busy ( not reading configuration from I2C)
Bit [2]:
1: BIST in progress 0: BIST not running
Bit [3]:
1: RAM Error 0: RAM OK
Bit [5:4]:
Device Signature 10: ZL50416 device
Bit [7:6]:
Revision 00: Initial Silicon 01: XA1 Silicon 10: Production Silicon
12.3.9.3
DCR1 - Chip Status
CPU Address: hF02 Accessed by CPU and serial interface. (RO) 7 CIC Bit [7] Chip initialization completed 6 4 3 2 1 0
118
Zarlink Semiconductor Inc.
ZL50416
12.3.9.4 DPST - Device Port Status Register
Data Sheet
CPU Address:hF03 Accessed by CPU and serial interface (R/W) Bit [4:0]: Read back index register. This is used for selecting what to read back from DTST. (Default 00) - 5'b00000 - Port 0 Operating mode and Negotiation status - 5'b00001 - Port 1 Operating mode and Negotiation status - 5'b00010 - Port 2 Operating mode and Negotiation status - 5'b00011 - Port 3 Operating mode and Negotiation status - 5'b00100 - Port 4 Operating mode and Negotiation status - 5'b00101 - Port 5 Operating mode and Negotiation status - 5'b00110 - Port 6 Operating mode and Negotiation status - 5'b00111 - Port 7 Operating mode and Negotiation status - 5'b01000 - Port 8 Operating mode and Negotiation status - 5'b01001 - Port 9 Operating mode and Negotiation status - 5'b01010 - Port 10 Operating mode and Negotiation status - 5'b01011 - Port 11 Operating mode and Negotiation status - 5'b01100 - Port 12 Operating mode and Negotiation status - 5'b01101 - Port 13 Operating mode and Negotiation status - 5'b01110 - Port 14 Operating mode and Negotiation status - 5'b01111 - Port 15 Operating mode and Negotiation status - 5'b10xxx - Reserved - 5'b11000 - Port 24 Operating mode/Neg status (CPU port)
119
Zarlink Semiconductor Inc.
ZL50416
12.3.9.5 DTST - Data read back register
Data Sheet
CPU Address: hF04 Accessed by CPU and serial interface (RO) This register provides various internal information as selected in DPST bit[4:0]. Application Note. 7 6 5 4 3 Inkdn When bit is 1: Bit [0] - Flow control enable Bit [1] - Full duplex port Bit [2] - Fast Ethernet port Bit [3] - Link is down Bit [4] - Reserved Bit [5] - Reserved Bit [6] - Reserved Bit [7] - Reserved 2 FE 1 Fdpx Refer to the PHY Control
0 FcEn
12.3.9.6
DA - Dead or Alive Register
CPU Address: hFFF Accessed by CPU and serial interface (RO) Always return 8'h DA. Indicate the CPU interface or serial port connection is good.
120
Zarlink Semiconductor Inc.
ZL50416
12.4 12.4.1 Characteristics and Timing Absolute Maximum Ratings
-65C to +150C -40C to +85C +125C +3.0V to +3.6V +2.38V to +2.75V +0.5V to (VCC + 3.3V)
Data Sheet
Storage Temperature Operating Temperature Maximum Junction Temperature Supply Voltage VCC with Respect to VSS Supply Voltage VDD with Respect to VSS Voltage on Input Pins
Caution: Stress above those listed may damage the device. Exposure to the Absolute Maximum Ratings for extended periods may affect device reliability. Functionality at or above these limits is not implied.
12.4.2
DC Electrical Characteristics
TAMBIENT = -40C to +85C
VCC = 3.3V +/- 10% VDD = 2.5V +10% / -5%
121
Zarlink Semiconductor Inc.
ZL50416
12.4.3 Recommended Operating Conditions
Parameter Description Frequency of Operation Supply Current - @ 100 MHz (VCC=3.3 V) Supply Current - @ 100 MHz (VDD=2.5 V) Output High Voltage (CMOS) Output Low Voltage (CMOS) Input High Voltage (TTL 5 V tolerant) Input Low Voltage (TTL 5 V tolerant) Input Leakage Current (0.1 V < VIN < VCC) (all pins except those with internal pull-up/pulldown resistors) Output Leakage Current (0.1 V < VOUT < VCC) Input Capacitance Output Capacitance I/O Capacitance Thermal resistance with 0 air flow Thermal resistance with 1 m/s air flow Thermal resistance with 2 m/s air flow Thermal resistance between junction and case Thermal resistance between junction and board 2.0 2.4 0.4 Min. Typ. 100 250
Data Sheet
Symbol fosc ICC IDD VOH VOL VIH-TTL VIL-TTL IIL
Max.
Unit MHz mA mA V V V V A
1350
VCC + 2.0 0.8 10
IOL CIN COUT CI/O ja ja ja jc jb
10 5 5 7 11.2 10.2 8.9 3.1 6.6
A pF pF pF C/W C/W C/W C/W C/W
122
Zarlink Semiconductor Inc.
ZL50416
12.5 12.5.1 AC Characteristics and Timing Typical Reset & Bootstrap Timing Diagram
Data Sheet
RESIN#
RESETOUT# Tri-Stated
R1 R3
Bootstrap Pins Outputs Inputs
R2
Outputs
Figure 14 - Typical Reset & Bootstrap Timing Diagram
Symbol R1 R2 R3
Parameter Delay until RESETOUT# is tri-stated Bootstrap stabilization RESETOUT# assertion
Min.
Typ. 10 ns
Note: RESETOUT# state is then determined by the external pull-up/down resistor Bootstrap pins sampled on rising edge of RESIN#a
1 s
10 s 2 ms
Table 14 - Reset & Bootstrap Timing
a. The TSTOUT[8:0] pins will switch over to the LED interface functionality in 3 SCLK cycles after RESIN# goes high
123
Zarlink Semiconductor Inc.
ZL50416
12.5.2 Typical CPU Timing Diagram for a CPU Write Cycle
Data Sheet
P_A[2:0] TW S
AD D R 0 TWH TW S
AD D R 1 TW H
P_C S# TW A Activ e Tim e P_W E# TDH D ATA0 TDH D ATA1 TW R R ecov ery Tim e TW A Activ e Tim e
TDS P_D ATA (to dev ice) Set up tim e
T DS
H old tim e
Figure 15 - Typical CPU Timing Diagram for a CPU Write Cycle
Description Write Cycle Write Set up Time Write Active Time Write Hold Time Write Recovery time Data Set Up time Data Hold time Symbol TWS TWA TWH TWR TDS TDH
(SCLK=100 Mhz) Min. 10 20 2 30 10 2 Max.
(SCLK=125 Mhz) Min. 10 16 2 24 10 2 Max.
Refer to Figure 17
P_A and P_CS# to falling edge of P_WE# At least 2 SCLK cycles P_A and P_CS# to rising edge of P_WE# At least 3 SCLK cycles P_DATA to falling edge of P_WE# P_DATA to rising edge of P_WE#
124
Zarlink Semiconductor Inc.
ZL50416
12.5.3 Typical CPU Timing Diagram for a CPU Read Cycle
Data Sheet
P_A[2:0] TRS
AD D R 0 TRH T RS
AD D R 1 TRH
P_C S# TRA Activ e Tim e P_R D # TDI D ATA0 TDI D ATA1 TRR R ecov ery Tim e TRA Activ e Tim e
TDV P_D ATA (to C PU )
TDV
Valid tim e
Inv alid tim e
Figure 16 - Typical CPU Timing Diagram for a CPU Read Cycle
Description Read Cycle Read Set up Time Read Active Time Read Hold Time Read Recovery time Data Valid time Data Invalid time Symbol TRS TRA TRH TRR TDv TDI
(SCLK=100 Mhz) Min. 10 20 2 30 10 6 Max.
(SCLK=125 Mhz) Min. 10 16 2 24 10 6 Max.
Refer to Figure 18
P_A and P_CS# to falling edge of P_RD# At least 2 SCLK cycles P_A and P_CS# to rising edge of P_RD# At least 3 SCLK cycles P_DATA to falling edge of P_RD# P_DATA to rising edge of P_RD#
125
Zarlink Semiconductor Inc.
ZL50416
12.5.4 12.5.4.1 Local Frame Buffer SBRAM Memory Interface Local SBRAM Memory Interface A
Data Sheet
LA_CLK
L1 L2
LA_D[63:0]
Figure 17 - Local Memory Interface - Input Setup and Hold Timing
LA_CLK
L3-max L3-min
LA_D[63:0]
L4-max L4-min
LA_A[20:3]
L6-max L6-min
LA_ADSC#
L7-max L7-min
LA_WE[1:0]# ####
L8-max L8-min
LA_OE[1:0]#
L9-max L9-min
LA_WE#
L10-max L10-min
LA_OE#
Figure 18 - Local Memory Interface - Output Valid Delay Timing
126
Zarlink Semiconductor Inc.
ZL50416
-100 MHz Symbol L1 L2 L3 L4 L6 L7 L8 L9 L10 Parameter Min. (ns) LA_D[63:0] input set-up time LA_D[63:0] input hold time LA_D[63:0] output valid delay LA_A[20:3] output valid delay LA_ADSC# output valid delay LA_WE[1:0]#output valid delay LA_OE[1:0]# output valid delay LA_WE# output valid delay LA_OE# output valid delay 4 1.5 1.5 2 1 1 -1 1 1 7 7 7 7 1 7 5 CL = 25 pf CL = 30 pf CL = 30 pf CL = 25 pf CL = 25 pf CL = 25 pf CL = 25 pf Max. (ns) Note
Data Sheet
Table 15 - AC Characteristics - Local Frame Buffer SBRAM Memory Interface
127
Zarlink Semiconductor Inc.
ZL50416
12.5.5 Reduced Media Independent Interface
M_CLK
M6-max M6-min
Data Sheet
Mn_TXEN
M7-max M7-min
Mn_TXD[1:0]
Figure 19 - AC Characteristics - Reduced Media Independent Interface
M_CLK
M2
Mn_RXD
M3
Mn_CRS_DV
M4 M5
Figure 20 - AC Characteristics - Reduced Media Independent Interface
M_CLK=50 MHz Symbol M2 M3 M4 M5 M6 M7 Parameter Min. (ns) Mn_RXD[1:0] Input Setup Time Mn_RXD[1:0] Input Hold Time Mn_CRS_DV Input Setup Time Mn_CRS_DV Input Hold Time Mn_TXEN Output Delay Time Mn_TXD[1:0] Output Delay Time 4 1 4 1 2 2 11 11 CL = 20 pF CL = 20 pF Max. (ns) Note
Table 16 - AC Characteristics - Reduced Media Independent Interface
128
Zarlink Semiconductor Inc.
ZL50416
12.5.6 LED Interface
LED_CLK
LE5-max LE5-min
Data Sheet
LED_SYN
LE6-max LE6-min
LED_BIT
Figure 21 - AC Characteristics - LED Interface
Variable FREQ. Symbol Parameter Min. (ns) Max. (ns) Note
LE5 LE6
LED_SYN Output Valid Delay LED_BIT Output Valid Delay
-1 -1
7 7
CL = 30 pf CL = 30 pf
Table 17 - AC Characteristics - LED Interface
129
Zarlink Semiconductor Inc.
ZL50416
12.5.7 SCANLINK, SCANCOL Interface
SCANCLK
C5-max C5-min
Data Sheet
SCANLINK
C7-max C7-min
SCANCOL
Figure 22 - SCANLINK, SCANCOL Output Delay Timing
SCANCLK
C1 C2
SCANLINK
C3 C4
SCANCOL
Figure 23 - SCANLINK, SCANCOL Setup Timing
-25 MHz Symbol Parameter Min. (ns) Max. (ns) Note
C1 C2 C3 C4 C5 C7
SCANLINK input set-up time SCANLINK input hold time SCANCOL input setup time SCANCOL input hold time SCANLINK output valid delay SCANCOL output valid delay
20 2 20 1 0 0 10 10 CL = 30pf CL = 30pf
Table 18 - SCANLINK, SCANCOL Timing
130
Zarlink Semiconductor Inc.
ZL50416
12.6 MDIO Interface
Data Sheet
MDC
D1 D2
MDIO
Figure 24 - MDIO Input Setup and Hold Timing
MDC
D3-max D3-min
MDIO
Figure 25 - MDIO Output Delay Timing
1 MHz Symbol Parameter Min. (ns) Max. (ns) Note:
D1 D2 D3
MDIO input setup time MDIO input hold time MDIO output delay time
10 2 1
Table 19 - MDIO Timing
20
CL = 50 pf
131
Zarlink Semiconductor Inc.
ZL50416
12.6.1 I2C Interface
Data Sheet
SCL
S1 S2
SDA
Figure 26 - I 2C Input Setup Timing
SCL
S3-max S3-min
SDA
Figure 27 - I2C Output Delay Timing
50 KHz Symbol Parameter Min. (ns) Max. (ns) Note
S1 S2 S3*
SDA input setup time SDA input hold time SDA output delay time
20 1 4 usec 6 usec CL = 30 pf
* Open Drain Output. Low to High transistor is controlled by external pullup resistor.
Table 20 - I2C Timing
132
Zarlink Semiconductor Inc.
ZL50416
12.6.2 Synchronous Serial Interface
STROBE
D1 D2
Data Sheet
D4 D1 D2
D5
D0
Figure 28 - Serial Interface Setup Timing
STROBE
D3-max D3-min
AutoFd
Figure 29 - Serial Interface Output Delay Timing Symbol Parameter Min. (ns) Max. (ns) Note
D1 D2 D3 D4 D5
D0 setup time D0 hold time AutoFd output delay time Strobe low time Strobe high time
20 3 s 1 5 s 5 s
Table 21 - Serial Interface Timing
50
CL = 100 pf
133
Zarlink Semiconductor Inc.
E1
E
DIMENSION A A1 A2 D D1 E E1 b e
MIN MAX 2.20 2.46 0.50 0.70 1.17 REF 37.70 37.30 34.50 REF 37.70 37.30 34.50 REF 0.60 0.90 1.27 553 Conforms to JEDEC MS - 034
e D D1
A2 b
NOTE:
1. CONTROLLING DIMENSIONS ARE IN MM 2. DIMENSION "b" IS MEASURED AT THE MAXIMUM SOLDER BALL DIAMETER 3. SEATING PLANE IS DEFINED BY THE SPHERICAL CROWNS OF THE SOLDER BALLS. 4. N IS THE NUMBER OF SOLDER BALLS 5. NOT TO SCALE. 6. SUBSTRATE THICKNESS IS 0.56 MM
Package Code
ISSUE ACN DATE APPRD.
Previous package codes:
For more information about all Zarlink products visit our Web Site at
www.zarlink.com
Information relating to products and services furnished herein by Zarlink Semiconductor Inc. or its subsidiaries (collectively "Zarlink") is believed to be reliable. However, Zarlink assumes no liability for errors that may appear in this publication, or for liability otherwise arising from the application or use of any such information, product or service or for any infringement of patents or other intellectual property rights owned by third parties which may result from such application or use. Neither the supply of such information or purchase of product or service conveys any license, either express or implied, under patents or other intellectual property rights owned by Zarlink or licensed from third parties by Zarlink, whatsoever. Purchasers of products are also hereby notified that the use of product in certain ways or in combination with Zarlink, or non-Zarlink furnished goods or services may infringe patents or other intellectual property rights owned by Zarlink. This publication is issued to provide information only and (unless agreed by Zarlink in writing) may not be used, applied or reproduced for any purpose nor form part of any order or contract nor to be regarded as a representation relating to the products or services concerned. The products, their specifications, services and other information appearing in this publication are subject to change by Zarlink without notice. No warranty or guarantee express or implied is made regarding the capability, performance or suitability of any product or service. Information concerning possible methods of use is provided as a guide only and does not constitute any guarantee that such methods of use will be satisfactory in a specific piece of equipment. It is the user's responsibility to fully determine the performance and suitability of any equipment using such information and to ensure that any publication or data used is up to date and has not been superseded. Manufacturing does not necessarily include testing of all functions or parameters. These products are not suitable for use in any medical products whose failure to perform may result in significant injury or death to the user. All products and materials are sold and services provided subject to Zarlink's conditions of sale which are available on request.
Purchase of Zarlink's I2C components conveys a licence under the Philips I2C Patent rights to use these components in and I2C System, provided that the system conforms to the I2C Standard Specification as defined by Philips. Zarlink, ZL and the Zarlink Semiconductor logo are trademarks of Zarlink Semiconductor Inc. Copyright Zarlink Semiconductor Inc. All Rights Reserved.
TECHNICAL DOCUMENTATION - NOT FOR RESALE


▲Up To Search▲   

 
Price & Availability of ZL50416

All Rights Reserved © IC-ON-LINE 2003 - 2022  

[Add Bookmark] [Contact Us] [Link exchange] [Privacy policy]
Mirror Sites :  [www.datasheet.hk]   [www.maxim4u.com]  [www.ic-on-line.cn] [www.ic-on-line.com] [www.ic-on-line.net] [www.alldatasheet.com.cn] [www.gdcy.com]  [www.gdcy.net]


 . . . . .
  We use cookies to deliver the best possible web experience and assist with our advertising efforts. By continuing to use this site, you consent to the use of cookies. For more information on cookies, please take a look at our Privacy Policy. X